#include <stdio.h> #include <stdlib.h> int main (void) { FILE *fp; char ch; if ((fp = fopen ("test.txt", "w+")) == NULL) { puts ("Cannot open file!"); exit (1); } puts ("请输入字符:"); while ((ch = getchar ()) != '\n') putc (ch, fp); //rewind (fp); while ((ch = getc(fp)) != EOF) putchar (ch); fclose (fp); return 0; }
程序如上,如果把rewind (fp) 注释掉则输出结果为:
如果把rewind 加上,则输出正常。
1.我想知道那么多“屯”哪来的,屯的数量是怎么确定的。
2.输入字符后没有关闭文件,会不会字符仍在缓冲区,没有写入文件,所以无法读出?
当我打开文件后看到
文件里有字符,输出只是屯,以上结果是不是可以证明,在输出文件内容的时候,确实没有把缓冲区的字符读入文件。但是屯是怎么读入的呢?还有最后的一个问号。
3. 试着读入后关闭文件,然后再以只读方式打开,代码如下
#include <stdio.h> #include <stdlib.h> int main (void) { FILE *fp; char ch; if ((fp = fopen ("test.txt", "w+")) == NULL) { puts ("Cannot open file!"); exit (1); } puts ("请输入字符:"); while ((ch = getchar ()) != '\n') putc (ch, fp); fclose (fp); //rewind (fp); if ((fp = fopen ("test.txt", "r")) == NULL) { puts ("Cannot open file!"); exit (1); } while ((ch = getc(fp)) != EOF) putchar (ch); fclose (fp); return 0; }
运行一切正常。写入正常,没有屯字出现。证明刚开始确实没有把缓冲区中的字符写入文件。但是
使用rewind() 函数的功能: 将文件内部的位置指针重新指向一个流(数据流/文件)的开头
所以输出无误。