►Управление строками...100
Для работы со строками в С++ можно использовать стандартные библиотечные функции. Некоторые из них намного сложнее, чем может показаться с первого взгляда. В табл. 7.1 перечислен ряд таких стандартных функций.
_________________
100 стр. Часть 2. Становимся функциональными программистами
Таблица 7.1. Функции, обрабатывающие строки
_________________
Название — Действие
¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯
int strlen( string ) — Возвращает количество символов в строке ( без учёта нулевого символа )
char* strcat( target , source ) — Присоединяет строку source к концу строки target
char* strcpy( target , source ) — Копирует строку source в target
char* strncat( target , source , n ) — Присоединяет не более n символов строки source к концу строки target
char* strncpy( target , source , n ) — Копирует не более n символов строки source в target
char* strstr( source1 , source2 ) — Находит первое вхождение строки source2 в source1
int strcmp( source1 , source2 ) — Сравнивает две строки
int stricmp( source1 , source2 ) — Сравнивает две строки без учёта регистра символов
¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯
Чтобы использовать функции работы со строками, нужно добавить в начале программы директиву #include <strings.h>.
«Текущий стандарт С++ предлагает избегать использования функций str...( ). В настоящее время компиляторы С++ поддерживают эти функции, но в один прекрасный день могут и перестать это делать. Именно с тем, что это устаревшие функции, связано использование расширения .h в директиве #include <strings.h>. Стандарт рекомендует использовать для работы с символьными строками специальный тип string.»
[Атас!]
В качестве примера использования функций str...( ) рассмотрим следующую программу, которая получает две строки, вводимые с клавиатуры, и объединяет их в одну строку.
/* Concatenate — объединение двух строк, которые разделяются символом " — " */
#include <cstdio>
#include <cstdlib>
#include <iostream>
using namespace std ;
/* Включаем файл, необходимый для использования функций работы со строками */
#include <strings.h>
int main( int nArg , char* pszArgs[ ] )
{
setlocale ( LC_ALL , ".1251" ) ; /* печать русских текстов */
/* Считываем первую строку... */
char szString1[ 256 ] ;
cout << "Введите строку #1: " ;
cin >> szString1 ;
/* Более безопасный вариант: cin.getline( szString1 , 128 ) ; */
/* ...теперь вторую... */
char szString2[ 128 ] ;
cout << "Введите строку #2: " ;
cin >> szString2 ;
/* Более безопасный вариант: cin.getline( szString2 , 128 ) ; */
_________________
101 стр. Глава 7. Хранение последовательностей в массивах
/* Объединяем строки */
char szString[ 260 ] ;
/* Копируем первую строку в буфер */
strncpy( szString , szString1 , 128 ) ;
/* Добавляем разделитель */
strncat( szString , " — " , 4 ) ;
/* ...теперь добавим вторую строку... */
strncat( szString , szString2 , 128 ) ;
/* ...и выведем результат на экран */
cout << " " << szString << endl ;
/* Пауза для того, чтобы посмотреть на результат работы программы */
system( "PAUSE" ) ; return 0 ;
}
«Порядок аргументов функций str...( ) может показаться "обратным". Хотя смотря что считать правильным порядком. Например, strcat( targer , source ) дописывает source к концу target, что выглядит вполне логично.»
[Помни!]
Вот пример работы программы:
Введите строку #1: Шарик
Введите строку #2: собака
Шарик - собака
Press any key to continue...
Программа начинается со считывания вводимой с клавиатуры строки cin >> szString1. При этом информация считывается до первого пробела, пробелы пропускаются, и оставшаяся часть строки будет считана в следующей инструкции cin >>.
«Кроме того, инструкция cin >> ничего не знает о длине строки. Она может прочесть тысячу символов и попытаться запихнуть их в массив, размер которого только 256 символов. Это опасно, кроме прочего, ещё и тем, что может послужить дырой, через которую хакеры смогут проникнуть в ваш компьютер...»
[Атас!]
«С++ предоставляет массу возможностей обойти такие узкие места. Например, функция getline( ) считывает строку текста, но при этом она знает максимальное количество символов, которые можно считать:
cin.getline( string , lengthOfTheString ) ;
( Пока что не обращайте внимания на странную приставку cin.. )»
[Советы]
Функции strncpy( ) и strncat( ) в качестве одного из аргументов получают длину целевого буфера. Вызов strncpy( szString , szString1 , 128 ) означает "копировать в szString символы из szString1, пока не будет скопирован нулевой символ или пока не будет скопировано 128 символов". Это не означает, что всякий раз будет копироваться ровно 128 символов.
_________________
102 стр. Часть 2. Становимся функциональными программистами
«Имеются версии функций с передаваемой длиной буфера и без неё. Последние следует использовать, когда вы твёрдо знаете, что переполнение целевого буфера возникнуть не может.»
[Атас!]
Больше книг — больше знаний!
Заберите 20% скидку на все книги Литрес с нашим промокодом
ПОЛУЧИТЬ СКИДКУ