C语言中的检测文件流是否结束的函数feof
2014-04-24 15:13
246 查看
1函数名
feof
2功
能
检测流上的文件结束符
The function feof() tests the end-of-file indicator
for the stream
pointed to by stream, returning non-zero
if it is set. The end-of-file
indicator can only be cleared by the functionclearerr().
如果文件结束,则返回非0值,否则返回0,文件结束符只能被clearerr()清除。
3用
法
int feof(FILE *stream);
程序例子
#include<stdio.h>
int main(void)
{
FILE*stream;
/*openafileforreading*/
stream=fopen("DUMMY.FIL","r");
/*readacharacterfromthefile*/
fgetc(stream);
/*checkforEOF*/
if(feof(stream))
printf("Wehavereachedend-of-file\n");
/*closethefile*/
fclose(stream);
return 0;
}
feof(fp)有两个返回值:如果遇到文件结束,函数feof(fp)的值为非零值,否则为0。
EOF是文本文件结束的标志。在文本文件中,数据是以字符的ASCⅡ代码值的形式存放,普通字符的ASCⅡ代码的范围是32到127(十进制),EOF的16进制代码为0x1A(十进制为26),因此可以用EOF作为文件结束标志。[1]
当把数据以二进制形式存放到文件中时,就会有-1值的出现,因此不能采用EOF作为二进制文件的结束标志。为解决这一个问题,ASCI
C提供一个feof函数,用来判断文件是否结束。feof函数既可用以判断二进制文件又可用以判断文本文件。
“C”语言的“feof()”函数和数据库中“eof()”函数的运作是完全不同的。数据库中“eof()”函数读取当前指针的位置,“C”语言的“feof()”函数返回的是最后一次“读操作的内容”。多年来把“位置和内容”相混,从而造成了对这一概念的似是而非。
那么,位置和内容到底有何不同呢?举个简单的例子,比如有人说“你走到火车的最后一节车箱”这就是位置。而如果说“请你一直向后走,摸到铁轨结束”这就是内容。也就是说用内容来判断会“多走一节”。这就是完全依赖于“while(!feof(FP)){...}”进行文件复制时,目标文档总会比源文档“多出一些”的原因。
在“C”文件读取操作时不能完全依赖于“while(!feof(FP)){...}”的判断。下面代码是改进后的代码,该代码执行后output文件内容和input文件内容一致,与使用“while(!feof(FP)){...}”相比,output文件的结尾符号(EOF)没有被读入到input文件中。
//main.c linux
下编译通过、vc下也行。
#include <stdlib.h>
#include <stdio.h>
int main(void)
{
FILE *in, *out;
int ch;
if ((in =
fopen("./output.txt",
"r"))==
NULL) //input.txt must exist in current directory.
{
fprintf(stderr,
"Cannot open inputfile\n");
exit(0);
}
if((out=fopen("./input.txt","w"))==NULL)
{
fprintf(stderr,"Can not open the file.\n");
exit(0);
}
while(1)
{
ch=fgetc(in);
if(ch == -1)
break;
fprintf(stdout,"The ASC of char %c is %d\n ",ch,ch);
fputc(ch,out);
}
fclose(in);
fclose(out);
return 0;
}
与EOF的区别
在stdio.h中可以看到如下定义:
#define EOF (-1)
#define _IOEOF 0x0010
#define feof(_stream) ((_stream)->_flag & _IOEOF)
int c;
while(!feof(fp))
{
c = fgetc(fp);
printf("%X\n", c);
}
会发现多输出了一个FF,原因就是在读完最后一个字符后,fp->flag仍然没有被置为_IOEOF,因而feof()仍然没有探测到文件结尾。直到再次调用fgetc()执行读操作,feof()才能探测到文件结尾。这样就多输出了一个-1(即FF)。
正确的写法应该是:
int c;
c = fgetc(fp);
while(!feof(fp))
{
printf("%X\n", c);
c = fgetc(fp);
}
feof()可以用EOF代替吗?不可以。fgetc返回-1时,有两种情况:读到文件结尾或是读取错误。因此我们无法确信文件已经结束,
因为可能是读取错误! 这时我们需要feof()。
feof
2功
能
检测流上的文件结束符
The function feof() tests the end-of-file indicator
for the stream
pointed to by stream, returning non-zero
if it is set. The end-of-file
indicator can only be cleared by the functionclearerr().
如果文件结束,则返回非0值,否则返回0,文件结束符只能被clearerr()清除。
3用
法
int feof(FILE *stream);
程序例子
#include<stdio.h>
int main(void)
{
FILE*stream;
/*openafileforreading*/
stream=fopen("DUMMY.FIL","r");
/*readacharacterfromthefile*/
fgetc(stream);
/*checkforEOF*/
if(feof(stream))
printf("Wehavereachedend-of-file\n");
/*closethefile*/
fclose(stream);
return 0;
}
feof(fp)有两个返回值:如果遇到文件结束,函数feof(fp)的值为非零值,否则为0。
EOF是文本文件结束的标志。在文本文件中,数据是以字符的ASCⅡ代码值的形式存放,普通字符的ASCⅡ代码的范围是32到127(十进制),EOF的16进制代码为0x1A(十进制为26),因此可以用EOF作为文件结束标志。[1]
当把数据以二进制形式存放到文件中时,就会有-1值的出现,因此不能采用EOF作为二进制文件的结束标志。为解决这一个问题,ASCI
C提供一个feof函数,用来判断文件是否结束。feof函数既可用以判断二进制文件又可用以判断文本文件。
“C”语言的“feof()”函数和数据库中“eof()”函数的运作是完全不同的。数据库中“eof()”函数读取当前指针的位置,“C”语言的“feof()”函数返回的是最后一次“读操作的内容”。多年来把“位置和内容”相混,从而造成了对这一概念的似是而非。
那么,位置和内容到底有何不同呢?举个简单的例子,比如有人说“你走到火车的最后一节车箱”这就是位置。而如果说“请你一直向后走,摸到铁轨结束”这就是内容。也就是说用内容来判断会“多走一节”。这就是完全依赖于“while(!feof(FP)){...}”进行文件复制时,目标文档总会比源文档“多出一些”的原因。
在“C”文件读取操作时不能完全依赖于“while(!feof(FP)){...}”的判断。下面代码是改进后的代码,该代码执行后output文件内容和input文件内容一致,与使用“while(!feof(FP)){...}”相比,output文件的结尾符号(EOF)没有被读入到input文件中。
//main.c linux
下编译通过、vc下也行。
#include <stdlib.h>
#include <stdio.h>
int main(void)
{
FILE *in, *out;
int ch;
if ((in =
fopen("./output.txt",
"r"))==
NULL) //input.txt must exist in current directory.
{
fprintf(stderr,
"Cannot open inputfile\n");
exit(0);
}
if((out=fopen("./input.txt","w"))==NULL)
{
fprintf(stderr,"Can not open the file.\n");
exit(0);
}
while(1)
{
ch=fgetc(in);
if(ch == -1)
break;
fprintf(stdout,"The ASC of char %c is %d\n ",ch,ch);
fputc(ch,out);
}
fclose(in);
fclose(out);
return 0;
}
与EOF的区别
在stdio.h中可以看到如下定义:
#define EOF (-1)
#define _IOEOF 0x0010
#define feof(_stream) ((_stream)->_flag & _IOEOF)
int c;
while(!feof(fp))
{
c = fgetc(fp);
printf("%X\n", c);
}
会发现多输出了一个FF,原因就是在读完最后一个字符后,fp->flag仍然没有被置为_IOEOF,因而feof()仍然没有探测到文件结尾。直到再次调用fgetc()执行读操作,feof()才能探测到文件结尾。这样就多输出了一个-1(即FF)。
正确的写法应该是:
int c;
c = fgetc(fp);
while(!feof(fp))
{
printf("%X\n", c);
c = fgetc(fp);
}
feof()可以用EOF代替吗?不可以。fgetc返回-1时,有两种情况:读到文件结尾或是读取错误。因此我们无法确信文件已经结束,
因为可能是读取错误! 这时我们需要feof()。
相关文章推荐
- C语言,如何产生随机数(各种转载)
- C++中预定义的运算符的操作对象只能是基本的数据类型
- C/C++字节对齐详解
- 二叉树的遍历 递归 非递归 C++ 实现
- C++ STL容器类vector使用范例
- Qt关于dll的生成和使用(Qt C++ li…
- c语言工具宏(调试信息)
- visualC++,求解一个小程序
- C++使用共享内存实现进程间通信
- c/c++ int _tmain(int argc, _TCHAR* argv[])
- protobuf c++ API
- c/c++中宏定义##连接符 和#符的使用
- 进程间通信_共享内存类_C++实现
- C++ 11 笔记 (四) : std::bind
- C++11 std::bind std::function 高级用法
- C++primer plus第六版课后编程题答案14.1
- 字符串分割单词(word break problem)问题几种解法之比较
- C语言实现邻接矩阵
- C/C++单元测试理论精要
- Python取模与C语言取模的差异