Как puts( )узнает, когда остановиться? Она прекращает работу, если встречает нуль-символ, поэтому лучше, чтобы он был. Не пытайтесь делать так!
/* нет строки! */
main( )
{
static char dont[ ] = (' H', ' Г , ' ! ', ' ! ');
puts(dont); /* dont не является строкой */
}
Поскольку в dontотсутствует завершающий нуль-символ, она не является строкой. Так как нуль-символ отсутствует, puts( )не знает, когда ей останавливаться. Она будет просто перебирать ячейки памяти, следующие за dontдо тех пор, пока не найдет где-нибудь нуль-символ. Если повезет, она, может быть, найдет его в ближайшей ячейке, но может и нe повезти.
Обратите внимание, что любая строка, вводимая функцией puts( ), начинается с новой строки. Если puts( )в конце концов находит завершающий нуль-символ, она заменяет его символом "новой строки" и затем выводит строку.
Мы уже обсуждали функцию printf( )довольно основательно. Подобно puts( ), она использует указатель строки в качестве аргумента. Функция printf( )менее удобна, чем puts( ), но более гибка.
Разница заключается в том, что printf( )не выводит автоматически каждую строку текста с новой строки. Вы должны указать, что хотите выводить с новых строк. Так,
printf(" %s\n" , string);
дает то же самое, что и
puts(string);
Вы можете видеть, что первый оператор требует ввода большего числа символов и большего времени при выполнении на компьютере. С другой стороны, printf( )позволяет легко объединять строки для печати их в одной строке. Например:
printf(" Хорошо, %s, %s \n", name, MSG);
объединяет " Хорошо" с именем пользователя и c символьной строкой MSGв одну строку.
СОЗДАНИЕ СОБСТВЕННЫХ ФУНКЦИЙ
Не ограничивайте себя при вводе и выводе только этими библиотечными функциями. Если у вас нет нужной функции, или она вам не нравится, можно создавать свои собственные версии, используя для этого getchar( )и putchar( ).
Предположим, у вас нет функции puts( ). Вот один из путей ее создания:
/* put1 - печатает строку */
put1(string);
char *string;
{
while(*string != '\0') putchar(*string++);
putchar('\n');
}
Символьный указатель stringвначале ссылается на первый элемент вызванного аргумента. После печати его содержимого указатель увеличивается и ссылается уже на следующий элемент. Это продолжается до тех пор, пока указатель не дойдет до элемента, содержащего нуль-символ. Затем в конце строки будет поставлен символ новой строки.
Предположим, у вас есть puts( ), но вам нужна функция, которая, кроме того, сообщает, сколько напечатано символов. Эту возможность легко добавить:
/* put2- - печатает строку и считывает символы */
put2 (string);
char *string;
{
int count = 0;
while(*string != '\0') {
putchar(* string++);
count++;
putchar('\n');
return(count);
}
Вызов:
put2(" пицца" );
печатает строку пицца, в то время как оператор
num = puts(" пицца");
передаст, кроме того, количество символов в num;в данном случае это число 5. Вот несколько более сложный вариант, показывающий вложенные функции:
/* вложенные функции */
#include
main( )
{
put1("Если бы я имел столько денег, сколько могу потратить,");
рrintf("Я считаю %d символа.\n",
put2(" Я никогда бы нe жаловался, что приходится чинить старые стулья.");
}
(Мы включили в программу при помощи директивы #includeфайл stdio.h, потому что в нашей системе в нем определена функция putchar( ), а она используется в нашей новой функции.)
Да-а, мы используем функцию printf( )для печати значения put2( ), но в процессе нахождения значения put2( )компьютер должен сначала заставить ее поработать - напечатать строку. Вот что получается при этом:
Если бы я имел столько денег, сколько могу потратить,
Я никогда бы нe жаловался, что приходится чинить старые стулья.
Я считаю 63 символа.
Теперь вы можете построить работающую версию функции gets( );она должна быть похожа на нашу функцию getint( )из гл. 10, но гораздо проще ее.
ФУНКЦИИ, РАБОТАЮЩИЕ СО СТРОКАМИ
Большинство библиотек языка Си снабжено функциями, работающими со строками. Рассмотрим четыре наиболее полезных и распространенных: strlen( ), strcat( ), strcmp( ) и strcpy( ).
Мы уже применяли функцию strlen( ), которая находит длину строки. Используем ее в нижеследующем примере функции, укорачивающей длинные строки.
Читать дальше