Язык программирования C


Массивы символов - часть 2


for(i=0;i<lim-1 && (c=getchar())!=EOF && c!='\n';++i) s[i] = c; if (c == '\n') { s[i] = c; ++i; } s[i] = '\0'; return(i); }

copy(s1, s2) /* copy s1 to s2; assume s2 big enough */ char s1[], s2[]; { int i;

i = 0; while ((s2[i] = s1[i]) != '\0') ++i; }

функция main и getline общаются как через пару аргументов, так и через возвращаемое значение. аргументы getline описаны в строках

char s[]; int lim;

которые указывают, что первый аргумент является массивом, а второй - целым.

Длина массива s не указана, так как она определена в main. функция getline использует оператор return для передачи значения назад в вызывающую программу точно так же, как это делала функция power. Одни функции возвращают некоторое нужное значение; другие, подобно copy, используются из-за их действия и не возвращают никакого значения.

Чтобы пометить конец строки символов, функция getline помещает в конец создаваемого ей массива символ \0 /нулевой символ, значение которого равно нулю/. Это соглашение используется также компилятором с языка "C": когда в "C" - программе встречается строчная константа типа

"hello\n"

то компилятор создает массив символов , содержащий символы этой строки, и заканчивает его символом \0, с тем чтобы функции, подобные printf, могли зафиксировать конец массива:

----------------------------------------- ! h ! e ! l ! l ! o ! \n ! \0 ! -----------------------------------------

Спецификация формата %s указывает, что printf ожидает строку, представленную в такой форме. Проанализировав функцию copy, вы обнаружите, что и она опирается на тот факт, что ее входной аргумент оканчивается символом \0, и копирует этот символ в выходной аргумент s2. /Все это подразумевает, что символ \0 не является частью нормального текста/.

Между прочим, стоит отметить, что даже в такой маленькой программе, как эта, возникает несколько неприятных организационных проблем. Например, что должна делать main, если она встретит строку, превышающую ее максимально возможный размер? функция getline поступает разумно: при заполнении массива она прекращает дальнейшее извлечение символов, даже если не встречает символа новой строки. Проверив полученную длину и последний символ, функция main может установить, не была ли эта строка слишком длинной, и поступить затем, как она сочтет нужным. Ради краткости мы опустили эту проблему.

Пользователь функции getline никак не может заранее узнать, насколько длинной окажется вводимая строка. Поэтому в getline включен контроль переполнения. В то же время пользователь функции copy уже знает /или может узнать/, каков размер строк, так что мы предпочли не включать в эту функцию дополнительный контроль.

Упражнение 1-14

Переделайте ведущую часть программы поиска самой длинной строки таким образом, чтобы она правильно печатала длины сколь угодно длинных вводимых строк и возможно больший текст.

Упражнение 1-15

Напишите программу печати всех строк длиннее 80 символов.

Упражнение 1-16

Напишите программу, которая будет удалять из каждой строки стоящие в конце пробелы и табуляции, а также строки, целиком состоящие из пробелов.

Упражнение 1-17

Напишите функцию reverse(s), которая располагает символьную строку s в обратном порядке. С ее помощью напишите программу, которая обратит каждую строку из файла ввода.




Начало  Назад  Вперед