C对字符串的常规处理也就只有借助一些标准的库函数了(string.h),所以这一章的内容很无聊,从头到尾比起教材目测更像一个函数说明书.........
鉴于C对字符串的构思都是建立在数组的基础上的,所以输入一个字符串的第一步永远是分配合适的内存空间。否则结果一般都会像超出数组长度那一样发生一些非常搞笑的事情...........
先写几个字符串的I/O函数声明:
char * gets ( char * ptr /*指向存放输入信息的位置*/ );
char * fgets ( char * ptr /*指向存放输入信息的位置*/ ,int n /*检测输入的最大长度(包括/0)*/ , ....../*输入源*/ );
int scanf ("%s", char* ptr/*指向存放输入信息的位置*/ );
void puts ( char* ptr /*指向输出信息的位置*/);
void fputs (char* ptr C, ....../*输出的位置*/ );
void ("%s",char* ptr /*指向输出信息的位置*/ );
绝大部分信息都包含在声明中了,直接说区别:gets()丢掉输入中的换行符,但是puts()为输出添加换行符;
fgets()储存输入中的换行符,fputs()不为输出添加换行符。所以这四个函数实际上是两两成对的,混用就要注意差别了。
一个要点:由于fgets()说明了读取字符串的最大长度,所以它不会造成超出范围的读取,相比于gets()要安全的多,所以在重要的程序中要尽量使用fgets()。
以及一个思考的问题:如果在使用gets()和fgets()时,在输入中存在/n,则函数是否会提前结束?
测试程序如下
#include<stdio.h>
#include<string.h>
int main (void)
{
char str1[80];
char str2[80];
gets(str1);
fgets(str2,80,stdin);
printf("%s",str1);
printf("%s",str2);
return 0;
}
//这是输入:abcdefg12345/0abcdefg12345
程序运行结果
看起来函数不会把输入中的/0当回事。。。。。。
把单斜杠换成双斜杠试试:
好吧还是没当回事。。。。。。。。
想了一下,大概是因为函数储存我输入的/0时分配在不同的内存空间中了,而代表空字符的/0在同一个内存单元中,所以要想使函数非正常结束(不输入回车结束),恐怕要靠一些非正常手段才行。
还有一个很重要的知识点:空指针是一个地址,而空字符是一个char类型的数据对象;NULL是一个指针,而0是一个char类型的常量。
妹的怪不得我以前写char ch = NULL;的时候怎么老是出错。。。。(╯‵□′)╯︵┻━┻
今天终于知道了。。。。。
补充:这些函数的声明我并没有找到原型,都是我自己的推测。。。。。。请勿参考