Программирование >>  Дополнительные возможности наследования 

1 ... 108 109 110 [ 111 ] 112 113 114 ... 265


Массивы символов

Строка текста представляет собой набор символов. Все строки, которые до сих пор использовались нами в программах, представляли собой безымянные строковые константы, используемые в выражениях с оператором cout, такие как:

cout << hello world.\n ;

Но в С+-Ь строку можно представить как массив символов, заканчивающийся концевым нулевым символом строки. Такой массив можно объявить и инициализировать точно так же, как любой другой массив, например:

char Greeting[] = { Н, е, Г, 1, о, , W.o,r,l,d, \0 };

В последний элемент массива заносится нулевой концевой символ строки (\0), который многие функции С-Ь+ распознают как символ разрыва строки. Хотя метод ввода строки текста в массив символ за символом работает нормально, это довольно утомительная процедура, чреватая ошибками. К счастью, С++ допускает упрошенный метод ввода строк текста в массивы;

char Greeting[] = hello world ;

Обратите внимание на два момента данного синтаксиса.

Вместо одиночных кавычек вокруг каждого символа, запятых между символами и фигурных скобок вокруг всей строки в данном примере используются только двойные кавычки вокруг строки и ничего более. Нет даже обычных для инициализации массивов фигурных скобок.

Нет необходимости добавлять концевой нулевой символ, так как компилятор сделает это автоматически.

Строка Hello World займет 12 байт. Пять байтов пойдет на слово Hello, пять на слово World и по одному байту на пробел и концевой нулевой символ.

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

В листинге 12.8 показан пример использования массива символов, который инициализируется строкой, вводимой пользователем с клавиатуры.

Аистинг 12.8. Заподненне массива симводами

2 3 4

5 6 7 8 9

10 11 12

Листинг 12.8. Заполнение массива символами

#include <iostrearn. h>

int main() {

char buffer[80]; cout Enter the string; ; cin >> buffer;

cout << Here is the buffer; << buffer << endl; return 0; }



, Enter the string; Hello World Heres the buffer; Hello

MTft* Ч < g строке 7 объявляется массив buffer, рассчитанный на 80 символов. Та-Ш* и Qp ассив может содержать строку из 79 букв, включая пробелы, плюс нулевой концевой символ строки.

В строке 8 пользователю предлагается ввести строку текста, которая копируется в массив buffer в строке 9. Метод cin автоматически добавит нулевой концевой символ в конце введенной строки.

Но при выполнении программы, показанной в листинге 12.8, возникает ряд проблем. Во-первых, если пользователь введет строку, содержащую более 79 символов, то оператор cin введет их за пределами массива, Во-вторых, оператор cin воспринимает пробел как окончание строки, после чего прекращает ввод данных.

Чтобы решить эти проблемы, нужно использовать метод get(), применяемый вместе с оператором cin: oin.get(). Для выполнения метода нужно задать три параметра.

Буфер ввода.

Максимальное число символов.

Разделительный символ прерывания ввода.

По умолчанию в качестве разделительного задается символ разрыва строки. Использование этого метода показано в листинге 12.9.

досшонг 12.В. Занодноное массова

1: Листинг 12.9, Использование метода cin.get() 2:

3: Sinclude <lostrearn. h> 4:

5: int malnO 6: {

7; char buffer[80]>

8; cout << Enter the string: ;

9: cin.get(buffer, 79); ввод завершается после 79 символа или символа разрыва строки cout Heres the buffer: buffer endl; return 0;

, . . Enter the string: Hello World Heres the buffer: Hello World

}, В строке 9 осуществляется вызов метода cin.get(). Буфер ввода, заданный

* в строке 7, передается в функцию как первый аргумент. Второй аргумент задает максимальную длину строки, равную 79 символам. Допускается ввод только 79 символов, поскольку последний элемент массива отводится на концевой нулевой символ строки. Устанавливать третий аргумент не обязательно. В большинстве случаев в качестве разделительного символа подходит задаваемый по умолчанию символ разрыва строки.



функции strcpyO u strncpyO

Язык С++ унаследовал от С библиотечные функции, выполняющие операции над строками. Среди множества доступных функций есть две, которые осуществляют копирование одной строки в другую. Это функции StrcpyO и StrncpyO. Функция StrcpyO копирует строку целиком в указанный буфер, как показано в листинге 12.10.

Аистинг 12.10. Исподьзование функцнн strcpyO

#include <iostrearn. h>

#include <string.h>

int main()

char String1[] = No man is an

island ;

6: 7

char String2[80];

Q

strcpy(String2,Stringi);

cout Stringi: Stringi

endl

11 :

cout String2: String2

endl

return 0;

Stringi: No man is an island String2: No man is an island

Файл заголовка strin.h включается в профамму в строке 2. Этот файл содержит прототип функции StrcpyO. В качестве аргументов функции указываются два массива символов, первый из которых является целевым, а второй - массивом источника данных. Если массив-источник окажется больще целевого массива, то функция StrcpyO введет данные за пределы массива.

Чтобы предупредить подобную ощибку, в этой библиотеке функций содержится еще одна функция копирования строк: strncpyO. Эта функция копирует ряд символов, не превышающий длины строки, заданной в целевом массиве. Функция strncpyO также прерывает копирование, если ей повстречается символ разрыва строки.

Использование функции strncpyO показано в листинге 12.11.

Листинг 12.11. Исиодьзоваиие функции strncpy()

#include <iostream.h> #include <string.h> int main() {

const int MaxLength = 80; char String1[] = No man is an island ; char String2[MaxLength+1];



1 ... 108 109 110 [ 111 ] 112 113 114 ... 265

© 2006 - 2025 pmbk.ru. Генерация страницы: 0
При копировании материалов приветствуются ссылки.
Яндекс.Метрика