0

在尝试计算文本文件中的行数时,我注意到 fgetc 总是返回 EOF。此代码在 Freebsd 10 上运行,但现在它不适用于 Mac OSX。我检查了文件看它是否为空,它不是,它的大小约为 1 KB,包含 16 行。我添加了一行来寻找文件的开头,认为这是问题所在,但它仍然返回 EOF。那么为什么 fgetc 总是返回 EOF?

 int getLines(int listFd, int *lines)
 {

     /* Declarations */
     *lines = 0;
     int ch;
     FILE *list;

     /* Get File Stream */
     list = fdopen(listFd, "r");
     if(list == NULL)
     {
         printf("Can't Open File stream\n");
         return -1;
     }

     /* Seek To beginning Of file */
     fseek(list, 0, SEEK_SET);

     /* Get Number of Lines */
     while(!feof(list))
     {
         ch = fgetc(list);
         if(ch == '\n')
         {
             lines++;
         }

         else if(ch == EOF)
         {
             break;
         }
     }

     printf("lines: %d\n", *lines);

     /* Clean up and Exit */
     fclose(list);

    return 0;
}
4

1 回答 1

0

fgetc() 最终应该EOF返回。代码的另一个问题肯定是混淆了行为和诊断。很适合测试 IO 功能的结果。

int getLines(int listFd, int *lines) {
  ...
  *lines = 0;
  ...
  if (fseek(list, 0, SEEK_SET)) puts("Seek error");
  ...
    ch = fgetc(list);
    if (ch == '\n') {
      // lines++;
      (*lines)++;  // @R Sahu 
    }
   ...
   printf("lines: %d\n", *lines);

   if (ferror(list)) puts("File Error - unexpected");
   if (feof(list)) puts("File EOF - expected");
}

其他的东西:

下面的代码是文件结束条件的冗余测试

/* Get Number of Lines */
while(!feof(list)) {
  ch = fgetc(list);
  ...
  else if(ch == EOF) {
    break;
  }
}

建议的简化(@Keith Thompson)

 /* Get Number of Lines */
 while( (ch = fgetc(list)) != EOF) {
   if(ch == '\n') {
     (*lines)++;
   }
 }

关于文件行数的小问题:如果文件在 final之后'\n'有文本,那会算作一行吗?建议:

*lines = 0;
int prev = '\n'; 
/* Get Number of Lines */
while( (ch = fgetc(list)) != EOF) {
  if(prev == '\n') {
    (*lines)++;
  }
  prev = ch;
}
于 2014-09-18T18:06:41.143 回答