假设我有一个程序可以处理C语言的二进制文件。
假设此二进制文件中有8个对象(每个对象都是struct记录类型),并且我已经读取了8个对象的前3个对象。(通过读取8个对象中的3个对象,我是说我已经读取并存储了将它们排列成一个数组)
我知道为了以后读取二进制文件的内容,我必须使用fseek调用来实现此目标。我感到困惑的是,假设我想读取8的第4个对象,我应该使用fseek调用移动/跳过多少个字节/对象?
我应该打电话
fseek(fp, sizeof(struct record) * 3, SEEK_SET);
或
fseek(fp, sizeof(struct record) * 4, SEEK_SET);
答案 0 :(得分:0)
通常最好将这些内容写下来,以了解内存映射的工作原理,所以让我们尝试表示文件(假设每个结构的大小为4个字节):
byte: |A-0|A-1|A-2|A-3|B-0|B-1|B-2|B-3|C-0|C-1|C-2|C-3|D-0|D-1|D-2|D-3|E....
----------------------------------------------------------------------
struct: | struct A |struct B |struct C |struct D |s...
----------------------------------------------------------------------
address:0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
从视觉表示中可以看到该文件是基于0的索引
即第一个结构位于地址0 (sizeof(struct record) * 0)
第二个位于地址4 (sizeof(struct record) *1)
等等...
从这里可以得出第n个元素offset = ( sizeof(struct record) * ( n - 1) )
希望它更清晰...