现在的位置: 首页 > 综合 > 正文

C语言为二维数组动态分配内存的问题

2013年02月09日 ⁄ 综合 ⁄ 共 682字 ⁄ 字号 评论关闭

转载请注明出处:http://blog.csdn.net/ns_code/article/details/11357667


C语言中动态分配一位数组是很简单的,但是没有可以直接对二维数组进行动态分配的函数,因此,要相对二维数组动态分配内存,便要借助于一位数组来实现,具体如下:

 

假设要为一个n*m的二维数组分配动态内存

 

首先需要注意的是,不要这样一次性分配为数组内存空间:

int **arr = (int**)malloc(n * m * sizeof(int));

正确的做法是先分配行,再分配列。

释放内存的时候,要先释放列,再释放行。

注意,顺序反了的话,会把列的地址擦除,导致释放列时内存时找不到地址,程序崩溃。

正确的分配空间代码如下:

 int **arr = (int **)malloc(n*sizeof(int *));
 for(i=0;i<n;i++)
     arr[i] = (int *)malloc(m*sizeof(int));

 

正确的释放空间代码如下:

 for (i = 0; i < n; i++)
     free(arr[i]);
/
*释放列*/

 free(arr);/*释放行*/

注:这种分配方式得到的其实并不是真正意义上的二维数组,因为其行与行之间的内存并不连续,虽然可以用下标arr[i][j]的方式访问,但当用指向该二维数组的指针来访问时候,不能通过指针值的增加来跨行获取元素,不过这种情况一般用的也不多,因此上述分配方式在大多数情况下的操作都能得到正确的结果。

一篇文章分析的不错,源地址:http://tsindahui.blog.sohu.com/84512010.html

抱歉!评论已关闭.