Chinaunix首页 | 论坛 | 博客
  • 博客访问: 550018
  • 博文数量: 181
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 1498
  • 用 户 组: 普通用户
  • 注册时间: 2013-12-22 15:17
个人简介

用发呆的时间来理清自己的思绪

文章存档

2015年(7)

2014年(134)

2013年(40)

分类: LINUX

2014-06-16 23:43:39

#include
        char *fgets(char *s, int size, FILE *stream);

功能:从文件流读取一行,送到缓冲区,使用时注意以下几点:
        返回值:成功时s指向哪返回的指针就指向哪,出错或者读到文件末尾时返回NUL

fgets函数,参数s是缓冲区的首地址,size是缓冲区的长度,该函数从stream所指的文件中读取以'\n'结尾的一行(包括'\n'在内)存到缓冲区s中,并且在该行末尾添加一个'\0'组成完整的字符串。

fgets()函数中,第一个参数指针需要我们事先分配好大小。另外,fgets()函数不适合取二进制的文件,这样,容易发生错误。

注:fgets从指定的文件中读一行字符到调用者提供的缓冲区中,gets从标准输入读一行字符到调用者提供的缓冲区中。

1.当遇到换行符或者缓冲区已满,fgets就会停止,返回读到的数据,值得注意的是不能用fgets读二进制文件,因为fgets会把二进制文件当成文本文件来处理,这势必会产生乱码。

2.每次调用,fgets都会把缓冲区的最后一个字符设为null,这意味着最后一个字符不能用来存放需要的数据,所以如果有一行,含有LINE_SIZE个字符(包括换行符),要想把这行读入缓冲区,请把参数n设为LINE_SIZE+1

3. 由结论1可推出:给定参数n,fgets只能读取n-1个字符(包括换行符),如果有一行超过n-1个字符,那么fgets返回一个不完整的行,也就是说,只读取该行的前n-1个字符,但是,缓冲区总是以null字符结尾,对fgets的下一次调用会继续读该行。

注意,对于fgets来说,'\n'是一个特别的字符,而'\0'并无任何特别之处,如果读到'\0'就当作普通字符读入。如果文件中存在'\0'字符(或者0x00字节),调用fgets之后就无法判断缓冲区中的'\0'究竟是从文件读上来的字符还是由fgets自动添加的结束符,所以fgets只适合读文本文件而不适合读二进制文件,并且文本文件中的所有字符都应该是可见字符,不能有'\0'。

#include

int fputs(const char *s, FILE *stream);
        int puts(const char *s);

返回值:成功返回一个非负整数,出错返回EOF

fputs向指定的文件写入一个字符串,puts向标准输出写入一个字符串。

缓冲区s中保存的是以'\0'结尾的字符串,fputs将该字符串写入文件stream,但并不写入结尾的'\0'。与fgets不同的是,fputs并不关心的字符串中的'\n'字符,字符串中可以有'\n'也可以没有'\n'。puts将字符串s写到标准输出(不包括结尾的'\0'),然后自动写一个' \n'到标准输出。
文章转自:

阅读(12151) | 评论(3) | 转发(0) |
0

上一篇:C语言顺序栈的实现

下一篇:ps -ef |grep java

给主人留下些什么吧!~~

hdst2016-08-13 21:34:54

作者认识的很透彻,今天帮初学者找资料看到这则博客,很不错。

hdst2016-08-13 21:33:12

akakaze:你说的fputs会自动写一个' \n'到标准输出是什么意思,并没有啊。而且我调试运行发现,用完fputs后再用fgets会出错,你有试试看么

你看错了吧。作者说puts会自动写一个\'\\n\'到标准输出,并没有说fputs会自动写一个\'\\n\'到标准输出,你说的没错,但看错了。至于用完fputs再用fgets出错,可能与编译器有关,在运行前执行一次缓冲区刷新操作fflush(stdin);应该就可以了。

回复 | 举报

akakaze2015-05-13 00:30:34

你说的fputs会自动写一个' \n'到标准输出是什么意思,并没有啊。而且我调试运行发现,用完fputs后再用fgets会出错,你有试试看么