C二进制文件读取:我应该移动多少字节?

时间:2019-03-18 06:56:58

标签: c binaryfiles fseek

假设我有一个程序可以处理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);

1 个答案:

答案 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) )

希望它更清晰...