#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() 函数的功能: 将文件内部的位置指针重新指向一个流(数据流/文件)的开头
所以输出无误。