我正在尝试在 C 代码中实现动态分配的连续 3D 数组。数组必须是连续的,因为我依赖于数组的 netCDF 输出。现在我改编了一个在这里发布的解决方案Stack OverFlow Solution。这对于动态分配数组和索引它们很有效……但是,当 netCDF 输出它们时,会有一个偏移量,它似乎可以缩放为第二个索引大小(jcount)。这是修改后的功能:
void*** newarray(int icount, int jcount, int kcount, int type_size)
{
int i,j,k;
void*** iret = (void***)malloc(icount*sizeof(void***)+icount*jcount*sizeof(void**)+icount*jcount*kcount*type_size);
void** jret = (void**)(iret+icount);
char* kret = (char*)(jret+icount*jcount);
for(i=0;i<icount;i++)
{
iret[i] = &jret[i*jcount];
}
for(i=0;i<icount;i++)
{
for(j=0;j<jcount;j++)
{
jret[i*jcount+j] = &kret[i*jcount*kcount*type_size+j*kcount*type_size];
}
}
return iret;
}
如果我正确理解这个函数,iret 会为组成 iret(第一个索引)的 3D 指针、组成 jret(第二个索引)的 2D 指针和组成 kret 的实际值分配空间。二维 jret 指针随后与 iret 的二维数组部分相关联。然后对 kret 进行同样的操作。然后 iret 的每个地址都指向 jret 的每个部分的第一个值。然后jret的每个地址都指向kret的首地址。
作为记录,一切正常,预处理器为我的数组定义的值。此外,如果我在代码中使用一些 printf 语句来检查数组的数字,它们似乎都正确索引并且代码运行正确,那么输出似乎是数组的非连续内存存储的结果。
我有一个形式的结构:
typedef struct
{
double ***test;
} STRUCT_TYPE;
然后我分配使用
mhd = (STRUCT_TYPE *) malloc(sizeof(STRUCT_TYPE));
mhd.test = (double***) newarray(101,7,101,sizeof(double));
这可能是 netCDF 的问题......但我只想知道我的分配例程不是问题。