我已经广泛搜索了这个并且现在花了4个小时卡住了,我希望有人可以帮助我。
我有一个简单的程序来读取二进制文件,大约2.7 MB。该程序使用tcc编译器在Windows上编译。我在各种高级语言(Pascal,Modula2,Matlab,PHP,Basic)方面经验丰富,但对C来说是新手,并且怀疑这会影响内存分配和变量被覆盖。
void main ()
{
long int start_loc;
long int actual_loc;
int seek_result;
char file_to_process[]="d:/tmp/pfc/test.out";
char read_int;
int spaces;
int read_result;
FILE *data_file;
//fpos_t position;
data_file=fopen(file_to_process,"r");
if (data_file == NULL) {
printf("Error");
}
start_loc = 1002;
printf("\n size of start_loc : %d",sizeof(start_loc));
actual_loc = ftell(data_file);
printf("\nBEFORE location %d \n",actual_loc);
seek_result = fseek(data_file, start_loc, SEEK_SET); //move to start of search location in the file
actual_loc = ftell(data_file);
printf("\n AFTER seek location %d \n",actual_loc);
fread(&read_int, 1, 1, data_file);
actual_loc = ftell(data_file);
printf("\n AFTER read location %d \n",actual_loc);
printf("\n read result %x" ,*&read_int);
fread(&read_int, 1, 1, data_file);
actual_loc = ftell(data_file);
printf("\n AFTER read location %d \n",actual_loc);
printf("\n read result %x" ,*&read_int);
fclose(data_file);
return;
}
在上面的示例中,我从文件中的位置1002读取 - 这很好 - 结果是:
size of start_loc : 4
BEFORE location 0
AFTER seek location 1002
AFTER read location 1003
read result 0
AFTER read location 1004
read result 3
一切都按预期工作 - 对于每个读取的字节,文件指针前进1个字符。
问题来自于起始位置的某些值,例如:
start_loc = 16000
在这种情况下,文件指针在命令之后以看似随机的方式跳转,例如即读取1个字节,文件指针移动到19586.
size of start_loc : 4
BEFORE location 0
AFTER seek location 16000
AFTER read location 19585
read result 47
AFTER read location 19586
read result 0
感谢您阅读此内容!
答案 0 :(得分:1)
您的文件在文本模式(r)中打开,在文本模式下,c ++参考说明了ftell函数: 对于文本流,数值可能没有意义但仍然可以用于稍后使用fseek将位置恢复到相同位置(如果使用ungetc放回的字符仍然等待被读取,则行为未定义)。
所以你得到的东西似乎与文档一致,不应该担心你。
请注意,如果要将其作为二进制文件打开,则应将“b”附加到fopen模式。