feof/perror

feof

  函数名: feof
  功 能: 检测流上的文件结束符
  用 法: int feof(FILE *stream);
  程序例:
  #include <stdio.h>
  int main(void)
  {
  FILE *stream;
  /* open a file for reading */
  stream = fopen("DUMMY.FIL", "r");
  /* read a character from the file */
  fgetc(stream);
  /* check for EOF */
  if (feof(stream))
  printf("We have reached end-of-file\n");
  /* close the file */
  fclose(stream);
  return 0;
  }
  feof(fp)有两个返回值:如果遇到文件结束,函数feof(fp)的值为1,否则为0。
  EOF是文件结束标志的文件。在文本文件中,数据是以字符的ASCⅡ代码值的形式存放,ASCⅡ代码的范围是0到255,不可能出现-1,因此可以用EOF作为文件结束标志。
  当把数据以二进制形式存放到文件中时,就会有-1值的出现,因此不能采用EOF作为二进制文件的结束标志。为解决这一个问题,ASCI C提供一个feof函数,用来判断文件是否结束。feof函数既可用以判断二进制文件又可用以判断文本文件。
  “C”语言的“feof()”函数和数据库中“eof()”函数的运做是完全不同的。数据库中“eof()”函数读取当前指针的位置,“C”语言的“feof()”函数返回的是最后一次“读操作的内容”。多年来把“位置和内容”相混,从而造成了对这一概念的似是而非。
  那么,位置和内容到底有何不同呢?举个简单的例子,比如有人说“你走到火车的最后一节车箱”这 就是位置。而如果说“请你一直向后走,摸到铁轨结果”这就是内容。也就是说用内容来判断会“多走一节”。这就是完全依赖于 “while(!feof(FP)){...}”进行文件复制时,目标文档总会比源文档“多出一些”的原因。
  在“C”文件读取操作时不能完全依赖于“while(!feof(FP)){...}”的判断。



perror()为向标准错误输出stderr打印一条最近一个库函数调用产生的错误,并设置重新全局变量

你可能感兴趣的:(职场,休闲,perror)