我遇到了一个奇怪的情况。我使用Dev C ++编写以下程序:
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
int main() {
FILE *fp; // edited -- wrong type at first (File)
unsigned char a, b;
int c, count, res; // added "res"
short int d;
fp = fopen("record.dat", "r");
fseek(fp, SEEK_SET, 0);
count = 0; // edited -- wrong variable name at first
res = fread(&a, 1, 1, fp);
printf("a res = %d, errno %d\n", res, errno);
while(count < 10) {
count++;
res = fread(&b, 1, 1, fp); // added "res =" as mentioned in comment
printf("b res = %d, errno %d\n", res, errno);
res = fread(&c, 4, 1, fp); // added "res =" as mentioned in
printf("c res = %d, errno %d\n", res, errno);
res = fread(&d, 2, 1, fp); // added "res =" as mentioned in
printf("d res = %d, errno %d\n", res, errno);
res = fread(&a, 1, 1, fp); // ** where problem starts
printf("a res = %d, errno %d\n", res, errno);
}
fclose(fp);
}
&#34; record.dat&#34;文件大小超过1MB,所以我认为上述程序可以毫无问题地获取前10个记录的数据(例如,不需要处理EOF
问题)。但是,当我在Dev C ++中编译程序并运行它时,在读取4条记录后,fread()
(由上面的**标记)返回0,然后while循环中的后续fread()
也返回0 ,意思是没有数据可以读取。更奇怪的是所有errno
都是0,当我在Linux中使用g ++编译器编译同一个程序时,程序可以读取同一文件中的所有记录(不仅仅是10个)而没有任何问题。 / p>
我有什么遗漏的吗?谢谢!
答案 0 :(得分:2)
如果您正在阅读二进制文件,则应使用"rb"
而不是"r"
打开它。否则你得到(平台特定的)“文本模式”处理。在Linux上,这不会改变任何内容,但在Windows上,这会将CR / LF(0D 0A
)转换为'\n'
,也可能将^Z
解释为文件的末尾。
您可以通过查看文件的十六进制转储来确认:如果您的程序神秘地停止在1A
处阅读,则问题就出现了。