int main(int argc, char* argv[])
{
char buf[256];
fpos_t pos;
fp=fopen("D:\\programme\\Dev-Cpp Portable\\32bit\\MinGW32\\include\\winsock2.h","r");
pp=fopen("errorfile.txt","a");
while(fgets (buf,256,fp)!=NULL){
fgetpos(fp,&pos);
fsetpos(fp,&pos);//当调用fsetpos函数时,空行会被跳过
fprintf(pp,"%s%d %d\n",buf,strlen(buf),pos);
}
fclose(pp);
fclose(fp);
}
读C语言头文件时,当调用fsetpos函数,空行就会被跳过,不用就没事,什么原因?
1、fgets函数:
原型:char * fgets(char * buf, int bufsize, FILE * stream);
功能:从文件结构体指针stream中读取数据,每次读取一行;
说明:读取的数据保存在buf指向的字符数组中,每次最多读取bufsize-1个字符(第bufsize个字符赋值为\0)。如果该行不足bufsize个字符,则读完该行就结束,如果该行超过bufsize-1个字符,则fgets只返回一个不完整的行,buf缓冲区以\0字符结束,下一次fgets调用会继续读取该行剩余的字符;
头文件:stdio.h;
返回值:若读入成功,返回与参数buf相同的字符指针,若读入过程中遇到EOF或发生错误,返回NULL指针。所以当遇到返回值为NULL的情况时,应使用ferror或feof函数检查是发生错误还是遇到EOF。
2、例程:
你确定你的代码能编译通过么?你的变量fp和pp都没声明!把fp和pp那两行改为
我在Linux上编译后测试,输出文件errorfile.txt没有区别。
追问这两个变量声明我忘写了 但这不是重点
重点是fsetpos函数,我调试程序不调用这个函数时可以正确读出文件内容,调用这个函数有些字符(比如说空行)就被略过了。
这是不调用fsetpos的情况:
这是调用fsetpos的情况
看到没,调用函数后空行不见了,按道理来说应该是有空行的,再有到了下边,#define前的#符号也不见。难道是系统的原因吗?
你把打开文件那行分别改为
和
fp=fopen("D:\\programme\\Dev-Cpp Portable\\32bit\\MinGW32\\include\\winsock2.h","rt"); // 纯文本模式打开试试。告诉我结果,或许有解。
这是rb模式:
只有rb模式能正确读出来,模式r和rt读不出来,这是为什么呢?.h文件不是文本文件吗?为什么要用rb模式来读?
你说rt模式读不出来是什么意思?是errorfile.txt为空,还是跟r模式的情况一样?
追问rt和r一样
只有rb能正确读出来
我估计跟Windows换行由两个字符标识\r\n【\r为CR(Carriage Return),\n为LF(Line Feed)】有关。Windows对文本模式打开的文件会作\r\n与\n的转换。但具体怎么交互产生了你看到的结果我还没有想清楚。用二进制模式不会开启这类转换,避免了复杂交互可能产生的问题。
追问好
既然问题解决就不要去想这个伤脑筋的事情了。
你下载一个DEVC++里面就有这个头文件
追答要一下你的那个原样的文件,我要复现一下这个问题
因为我没复现
三个1零2534 等你qq邮件
你的编译器是什么?
也是dev c++么?什么系统环境
追问我已放到我的百度网盘上
http://pan.baidu.com/s/1dDgP6jJ
用的是DEV C++/win7系统