包含数组的结构的fwrite

问题描述 投票:2回答:4

如何编写包含数组的结构

#include <iostream>
#include <cstdio>

typedef struct {
  int ref; 
  double* ary;
} refAry;

void fillit(double *a,int len){
  for (int i=0;i<len;i++) a[i]=i;
}

int main(){
  refAry a;
  a.ref =10;
  a.ary = new double[10];
  fillit(a.ary,10);
  FILE *of;
  if(NULL==(of=fopen("test.bin","w")))
     perror("Error opening file");
  fwrite(&a,sizeof(refAry),1,of);

  fclose(of);
  return 0;
}

test.bin的文件大小为16个字节,我猜是(4 + 8)(int + double *)。文件大小应为4 + 10 * 8(即时64位)

~$ cat test.bin |wc -c
16
~$ od -I test.bin 
0000000                   10             29425680
0000020
~$ od -fD test.bin -j4
0000004   0,000000e+00   7,089709e-38   0,000000e+00
                     0       29425680              0
0000020

谢谢

c++ struct fwrite fread
4个回答
2
投票

您正在将指针(内存地址)写入文件,这不是您想要的。您想要写入指针(数组)引用的内存块的内容。只需调用一次fwrite即可完成此操作。我建议你定义一个新功能:

void write_my_struct(FILE * pf, refAry * x)
{
    fwrite(&x->ref, sizeof(x->ref), 1, pf);
    fwrite(x->ary, sizeof(x->ary[0]), x->ref, pf);
}

你需要一个类似的替代fread。


1
投票

您的结构实际上不包含数组,它包含指针。如果你真的想要可变长度的结构,你需要在那里保留一个大小字段,以便你知道它有多大。 C FAQ有一个例子,它正是你想要做的。在你的情况下,它可能看起来像这样:

typedef struct {
    int ref; 
    double ary[1];
} refAry;

#define SIZE_OF_REFARY (sizeof(refAry) - sizeof(double))

分配:

size_t alloc_size = SIZE_OF_REFARY + 10*sizeof(double);
refAry *a = malloc(alloc_size);
a->ref = 10;

来写:

fwrite(a, SIZEP_OF-REFARY + a->ref * sizeof(double), 1, file);

0
投票

你的结构包含一个指针,而不是一个10的数组.sizeof()选择了它。

你需要像fwrite(a.ary,sizeof(double),10)之类的东西;为了写出实际的数组


0
投票

如果数组的大小始终为10,那么只需将结构更改为:

typedef struct {
  int ref; 
  double ary[10];
} refAry;

然后你可以通过一次调用fwrite来编写它,使用sizeof(refAry)作为大小。

© www.soinside.com 2019 - 2024. All rights reserved.