如果要给二维数组(m*n)分配空间,代码可以写成下面:
char **a, i;
// 先分配m个指针单元,注意是指针单元
// 所以每个单元的大小是sizeof(char *)
a = (char **) malloc(m * sizeof(char * ));
// 再分配n个字符单元,
// 上面的m个指针单元指向这n个字符单元首地址
for(i = 0; i < m; i++)
a[i] = (char * )malloc(n * sizeof(char ));
释放应该是:
int i; for(i=0;i<m;i++) free((void *)a[i]); free((void *)a); |
如果为三维数组(m*n*p)分配空间呢,应该是:
char ***a, i, j; a = (char ***) malloc(m * sizeof(char ** )); for(i = 0; i < m; ++i) a[i] = (char **) malloc(n * sizeof(char * )); for(i = 0; i < m; ++i) for(j = 0; j < n; ++j) a[i][j] = (char * )malloc(p * sizeof(char )); |
释放代码为逆过程,具体代码为:
int i,j,; for(i = 0; i < m; ++i) for(j = 0; j < n; ++j) free((void *)a[i][j]); for(i = 0; i < m; ++i) free((void *)a[i]); free((void *)a); |
三维以上的多维数组的分配和释放,原理与上面的一样。
另参考 http://blog.csdn.net/dualeak/article/details/4677132