Выбрать главу

[Атас!] 

В качестве примера использования функций 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 << "\n" << 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. Становимся функциональными программистами