7

可能重复:
“while(!feof(file))”总是错误的

如果我将数组写入输出文件并关闭文件,然后再次打开文件并读取所有内容,直到到达文件结尾,虽然文件只包含 4 个数字,但程序将读取并打印 5 个数字,为​​什么?

程序输出:

a[0] = 4
a[1] = 7
a[2] = 12
a[3] = 34
a[4] = 34

save.bin(带有十六进制编辑器)

04000000 07000000 0C000000 22000000

#include <stdio.h>
#include <stdlib.h>
#define path "save.bin"

int main(void)
{
  FILE *f=NULL;
  int a[]={4,7,12,34},i,n=4,k;
  f=fopen(path,"wb");
  if(f==NULL)
  {
    perror("Error");
    exit(1);
  }
  for(i=0;i<n;i++)  // or I could use fwrite(a,sizeof(int),n,f);
    fwrite(&a[i],sizeof(int),1,f);
  fclose(f);
  f=fopen(path,"rb");
  if(f==NULL)
  {
    perror("Error");
    exit(1);
  }
  i=0;
  while(!feof(f))
  {
    fread(&k,sizeof(int),1,f);
    printf("a[%d] = %d\n",i,k);
    i++;
  }
  printf("\n");
  fclose(f);
  return 0;
}
4

3 回答 3

11

feof(fp)仅当您尝试读取文件末尾之后才变为假(即非零值) 。这应该可以解释为什么输入的循环比您预期的多一个。

文档中:

  The function feof() tests the end-of-file indicator for the stream
  pointed to by stream, returning nonzero if it is set.  The end-of-
  file indicator can be cleared only by the function clearerr().

另请阅读帖子:为什么“while (!feof (file))”总是错误的?

于 2012-08-23T15:22:48.587 回答
1
while(!feof(f))
{
    fread(&k,sizeof(int),1,f);
    printf("a[%d] = %d\n",i,k);  /** THIS ASSUMES fread() WAS SUCCESSFUL. **/
    i++;
}

在调用后立即检查文件结尾fread()或检查 的返回值fread(),它返回读取的项目数,在这种情况下应该是1。循环的可能重组:

while(1 == fread(&k,sizeof(int),1,f))
{
    printf("a[%d] = %d\n",i,k);
    i++;
}

在循环检查feof()以确保达到 EOF 并且循环由于其他一些故障而没有结束之后。

于 2012-08-23T15:21:26.607 回答
1

我也有同样的问题。试试这个:

i=0;
  while(true)
  {
    fread(&k,sizeof(int),1,f);
    if(feof(f))
        break;

    printf("a[%d] = %d\n",i,k);
    i++;
  }

除非您已阅读文件末尾,否则显然 feof 不会返回 true。我在将数组写入二进制文件时所做的是首先写入大小,所以我知道在读回它时我将要读取的确切数据量。

于 2012-08-23T15:31:54.123 回答