如果要給二維數(shù)組(m*n)分配空間,代碼可以寫成下面:
// 先分配m個(gè)指針單元,注意是指針單元
// 所以每個(gè)單元的大小是sizeof(char *)
a = (char **) malloc(m * sizeof(char * ));
// 再分配n個(gè)字符單元,
// 上面的m個(gè)指針單元指向這n個(gè)字符單元首地址
for(i = 0; i < m; i++)
a[i] = (char * )malloc(n * sizeof(char ));
釋放應(yīng)該是:
for(i=0;i<m;i++)
free((void *)a[i]);
free((void *)a);
如果為三維數(shù)組(m*n*p)分配空間呢,應(yīng)該是:
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 ));
釋放代碼為逆過程,具體代碼為:
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);
新聞熱點(diǎn)
疑難解答
圖片精選