C语言的问题,fread和fgets的区别是什么?

以下程序:
#include "stdio.h"
#include "string.h"
void main()
{
char xx[80][80];
FILE *fp;
int i=0;char *p;
if((fp=fopen("IN.DAT","r"))==NULL) ;
while(fgets(xx[i],80,fp)!=NULL)
{
p=strchr(xx[i],'\n');
if(p) *p=0;
i++;
}
for(i=0;i<10;i++)
puts(xx[i]);
}
这个为什么输出结果和用fread的输出结果不一样?用一次fgets之后为什么fp指针没有越界,又能完整的读出下一个字符串来?还有ip(p),p是指针,用if语句是判断p是什么意思呢?

fread和 fgets的区别:

fread :以字节位计算长度,按照指定的长度和次数读取数据,遇到结尾或完成指定长度读取后停止.
fgets :整行读取,遇到回车换行或结尾停止.在文本方式时使用.

读字符串函数fgets函数的功能是从指定的文件中读一个字符串到字符数组中,函数调用的形式为:
fgets(字符数组名,n,文件指针);
其中的n是一个正整数。表示从文件中读出的字符串不超过 n-1个字符。在读入的最后一个字符后加上串结束标志'\0'。
例如:fgets(str,n,fp);的意义是从fp所指的文件中读出n-1个字符送入字符数组str中。(按行读取)fgets()每次读入一行就会指向下一行.
所以把前面10行读进去了就清除. 然后下一次fgets()就是第十一行了.
fgets()怎么每次都是读一行?你怎么设定?

fread是用于整块数据的读写函数,可用来读写一组数据,如一个数组元素,一个结构变量的值等。
读数据块函数调用的一般形式为: fread(buffer,size,count,fp),其中:
buffer是一个指针,在fread函数中,它表示存放输入数据的首地址。
size 表示数据块的字节数。
count 表示要读写的数据块块数。
fp 表示文件指针。
例如: fread(fa,4,5,fp);
其意义是从fp所指的文件中,每次读4个字节(一个实数)送入实数组fa中,连续读5次,即读5个实数到fa中。

fread -- 读取文件(可安全用于二进制文件)在区分二进制文件和文本文件的系统上(如 Windows)打开文件时,fopen()
函数的 mode 参数要加上 'b'。$handle = fopen($filename, "rb");
温馨提示:答案为网友推荐,仅供参考
第1个回答  2010-03-12
fread()函数通常用于读取二进制数据,用它可以精确的指定要读取多少字节的数据.

fgets()函数通常用于读取ASCII文本,它的参数是一个字符数组.
第2个回答  2010-03-12
fread读入的内容不包括最后的字符串终结符,而fgets则包括这个,也就是说fread读入的内容不是字符串,因为少一个终结符,而fgets则读入的是一个字符串。
至于if(p)这个问题应该很明了,虽然p是指值,但是可以让指针指向NULL,这样的话就可以使用if(p)来判断指针是否指向了内存,若没有就跳过语句。
第3个回答  推荐于2016-08-11
读字符串函数fgets函数的功能是从指定的文件中读一个字符串到字符数组中,函数调用的形式为: fgets(字符数组名,n,文件指针); 其中的n是一个正整数。表示从文件中读出的字符串不超过 n-1个字符。在读入的最后一个字符后加上串结束标志'\0'。例如:fgets(str,n,fp);的意义是从fp所指的文件中读出n-1个字符送入字符数组str中。
fread是用于整块数据的读写函数,可用来读写一组数据,如一个数组元素,一个结构变量的值等。读数据块函数调用的一般形式为: fread(buffer,size,count,fp),其中buffer是一个指针,在fread函数中,它表示存放输入数据的首地址。 size 表示数据块的字节数。count 表示要读写的数据块块数。fp 表示文件指针。
例如:
fread(fa,4,5,fp); 其意义是从fp所指的文件中,每次读4个字节(一个实数)送入实数组fa中,连续读5次,即读5个实数到fa中。
第4个回答  推荐于2018-03-01
fgets函数用来从文件中读入字符串。fgets函数的调用形式如下:fgets(str,n,fp);此处,fp是文件指针;str是存放在字符串的起始地址;n是一个int类型变量。函数的功能是从fp所指文件中读入n-1个字符放入str为起始地址的空间内;如果在未读满n-1个字符之时,已读到一个换行符或一个EOF(文件结束标志),则结束本次读操作,读入的字符串中最后包含读到的换行符。因此,确切地说,调用fgets函数时,最多只能读入n-1个字符。读入结束后,系统将自动在最后加'\0',并以str作为函数值返回。

int fread(void *ptr, int size, int nitems, FILE *stream);
参 数:用于接收数据的地址(指针)(ptr)
单个元素的大小(size)
元素个数(nitems)
提供数据的文件指针(stream)

一个是读字符串,一个是读取指定大小的数据,
当然结果会不一样。

因为如果在未读满n-1个字符之时,已读到一个换行符或一个EOF(文件结束标志),则结束本次读操作,所以fgets之后fp不会越界。
p是指针,
如果
p=strchr(xx[i],'\n');
xx[i]中没有'\n',则p=NULL.
而NULL就是0.就不进入循环,就是说读取字符中,没有遇到换行符。根据fgets()知道最后一个就是字符串结束符‘\0';
如果
xx[i]中有'\n',则p!=NULL,p指向第一个出现换行符的地方。
进入循环,另换行符变成字符串结束符‘\0';
因为‘\0'的ASCII码值为0;
所以写成了*p=0;
不知道说清楚没,希望对你有帮助。本回答被提问者和网友采纳

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网