楼主:
eagle32 (バスケがしたいです)
2018-12-04 15:28:38大家好. 我对于电脑内存的理解不多. 只是常听说要避免内存碎片化.
所以就学了以下语法要一块连续内存去配制一个阵列. 但是当阵列太大时.
譬如50*50*50 的 double array 执行时就发生segmentaion fault. 请大家指教我哪里做错想错了.
谢谢大家.
#include <stdlib.h>
#include <stdio.h>
int main() {
double ***array;
double **ppData;
double *pData;
int l=50;
int m=50;
int n=50;
int i,j,k;
array = (double ***)calloc(l*m*n, l*sizeof(double **) + l*m*sizeof(double *) +
l*m*n*sizeof(double));
ppData = (double **) (array+l);
pData = (double *) (array+l+l*m);
for(i=0; i < l; i++)
{
array[i]=ppData;
ppData+=m;
for(j=0; j < m; j++)
{
array[i][j]=pData;
pData+=n;
}
}
for(i=0; i<l; i++)
for(j=0; j<m; j++)
for(k=0; k<n; k++)
printf("(%d, %d, %d)=%f\n", i,j,k,array[i][j][k]);
free(array);
return 0;
}
作者:
poyenc (发箍)
2018-12-04 22:46:00pData 的初始化也有问题, 只是指标大小相同所以算出来位址刚好是对的简单说以一个整数 c 来说, array + c 代表的涵义是从array指向的位置开始, 往后算 c 个 sizeof(*array) 物件之后的位址, 这里的 sizeof(*array) == sizeof(double**), 表示array + c 实际上是在预留 c 个 double** 的空间, 这部分没问题; 但在初始化 pData 的时候你用的方法却是和 ppData一样, 多预留 l*m 个 double** 空间给 double* 用