求大神指点,文件中EOF占位有关问题

求大神指点,文件中EOF占位问题
本帖最后由 u013193033 于 2013-12-26 01:40:34 编辑
 这是我的部分代码
        while ( !feof(fp_B) )      //fp_B指向文件B
{
ch = fgetc(fp_B);
str[i++] = ch;
}
我想问的是: 为什么这段代码会将文件B末尾的结束符(EOF)储存在str中

我将代码改为:
        ch = fgetc(fp_B);
        while ( !feof(fp_B) )
{
                str[i++] = ch;
ch = fgetc(fp_B);
}
就不会出现这种情况,为什么?

我跟踪了第一段代码的文件内部指针的移动情况(改了一部分代码)
        while ( !feof(fp_B) )
{
printf("%d\n", ftell(fp_B));
ch = fgetc(fp_B);  //每执行一次该语句,文件内部指针会右移,但最后一次出现了例外
printf("%c\n", ch);
printf("%d\n", ftell(fp_B));
str[i++] = ch;
}

输出结果为

求大神指点,文件中EOF占位有关问题

红色方框那里很奇怪,EOF的位置似乎占两个指针移动点,而且在第一个点处feof函数无法识别

------解决方案--------------------
feof的作用是,告诉你是否一定到了文件末尾,但是,它必须在已经读取失败一次之后才能告诉你到了文件末尾!所以想用它来避免读取失败是不可能的!
推荐的方法是一开始就获取到文件大小,自己控制每次读多少数据何时结束,什么文件流啊去死吧!
------解决方案--------------------
不要使用
while (条件)
更不要使用
while (组合条件)
要使用
while (1) {
 if (条件1) break;
 //...
 if (条件2) continue;
 //...
 if (条件3) return;
 //...
}
因为前两种写法在语言表达意思的层面上有二义性,只有第三种才忠实反映了程序流的实际情况。
典型如:
下面两段的语义都是当文件未结束时读字符
while (!feof(f)) {
 a=fgetc(f);
 //...
 b=fgetc(f);//可能此时已经feof了!
 //...
}
而这样写就没有问题:
while (1) {
 a=fgetc(f);
 if (feof(f)) break;
 //...
 b=fgetc(f);
 if (feof(f)) break;
 //...
}
类似的例子还可以举很多。

另外应该int ch;而不能char ch;,因为要区别'\xFF'和EOF即-1