►Управление строками...100

We use cookies. Read the Privacy and Cookie Policy

Для работы со строками в С++ можно использовать стандартные библиотечные функции. Некоторые из них намного сложнее, чем может показаться с первого взгляда. В табл. 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. Становимся функциональными программистами

«Имеются версии функций с передаваемой длиной буфера и без неё. Последние следует использовать, когда вы твёрдо знаете, что переполнение целевого буфера возникнуть не может.»

[Атас!]