提问人: 提问时间:3/23/2016 最后编辑:lost_in_the_source 更新时间:5/24/2022 访问量:10489
与 == EOF 与 feof 的混淆
Confusion with == EOF vs feof
问:
我打开了一个文件,在指针的地址下找到了流。我正在尝试查看文件是否为空。使用以下内容ptr
if (fgetc(ptr) != EOF)
按预期工作。当文件为空时,不执行该语句。当文件不为空时,不执行语句。
但是,使用
if (!feof(ptr))
始终执行语句。
为什么会这样?有没有办法使用该功能?feof
答:
feof(f)
将始终在打开文件后立即返回,因为 if 为您提供一个标志的值,该标志初始化为 false 并仅在至少一个读取操作失败后设置为 true。false
你可以这样使用:feof
fgetc(fp);
if (feof(fp))
...
feof
检查在读取后设置的文件结束指示器,该指示器试图在文件末尾或超过文件末尾读取。当您无法控制的代码从文件中读取,并且您希望在文件用尽后停止处理时,它非常有用。
评论
feof()
if (fgetc(fp) == EOF)
fgetc
feof
fgetc(fp) == EOF
feof
feof
feof
feof
feof
在 C 标准库中,“文件结束”不是一个独立的自检测条件。“文件结束”只是由前面的读取操作设置的文件状态。在执行读取操作之前,直到该读取操作碰到文件的实际末尾,否则不会设置“eof”状态并返回 0。feof()
C 标准库中的许多(大多数)标准 I/O 函数已经返回了一些可用于检测“文件结束”条件(如返回值)的完成代码。这意味着大多数时候调用是不必要的。fgetc()
EOF
feof()
换句话说,如果你把“文件末尾”看作是一堵砖墙,那么在C标准库中,仅仅站在那堵墙的正前方来检测它是不够的。有必要用你的额头撞到那堵墙,以发现它的存在。
当您打开一个空文件时,您从“就在墙前”的状态开始。此时尚未检测到“文件结束”条件。你必须尝试阅读一些东西,才能撞到那堵墙,从而检测到它的存在。
这种设计的原因完全合乎逻辑。C 语言旨在支持各种输入流和文件系统,包括 1) 根本不存储文件大小的文件系统,以及 2) 只知道近似文件大小的文件系统(例如四舍五入到最近的集群)。在此类文件系统中,文件的末尾通常由特殊标记指定。你不知道那个标记在哪里,直到你在阅读文件时遇到它。(出于同样的原因,C 流不保证支持从函数中的原点定位。SEEK_END
fseek
正如@Barmar在评论中指出的那样,没有预先确定的“文件结束”位置的输入流的一个更好的例子是链接到终端的标准输入。
评论
fgetc() == EOF
feof()
有没有办法使用该功能?
feof
是的,有。在输入函数返回一个值以指示它没有更多要处理的输入后,您可以调用和/或确定该条件是由到达输入末尾还是某些错误条件引起的。feof()
ferror()
这是 and 函数的唯一有效用途。feof()
ferror()
指示不再保留输入的结果因函数而异。例如,返回值 ,返回一个空指针,并返回小于请求的记录数的某个值。您需要阅读每个输入函数的文档以了解其工作原理。fgetc()
EOF
fgets()
fread()
评论
fread
返回小于请求的仅表示返回 0 时的 EOF 等效。
fread
函数返回成功读取的元素数,如果遇到读取错误或文件末尾,则该数可能小于 nmemb
。read()
fread()
fgetc()
fread()
fgetc
fgets
fread
然而,迟到的回答是添加 Stephen Kochan 的 Programming in C(第 4 版)第 367 页的有用引用:
记住,告诉你已经尝试阅读过去 文件的末尾,这与告诉你你只是 从文件中读取最后一个数据项。您必须读取最后一个数据项才能返回 零。
feof()
feof()
斜体我的。
评论