二维指针动态分配内存连续问题分析
2013-07-08 10:26
211 查看
当我们定义一个二维指针时,如果需要存储相应的数据,就需要我们动态的分配内存,这时,有一点是需要注意的,分配内存的方法不同,内存的连续性也是不相同的,首先,博主先贴出测试代码:
运行截图如下:
如图所示,两种分配内存的方法都能正确的分配内存,但是内存分配的空间确实不一样的。
分析:
第一种分配方法:
首先,是对每一行分配,也就是 nWidth 中的每一个进行分配,所以,我们可以看到每一行的内存都是连续的,每一个都占据四个字节
但是,为nHeight分配内存的时候,是随机的进行分配内存,所以内存的位置是不确定的,所以,出现了第一种情况
第二种分配方法:
首先,同样是为 p 分配内存,现在 p 指向一个位置
但是,在第二句中,我们需要注意,是直接在 p[0] 出分配了所有需要的内存,所以,这个时候就全部分配完了,而且由于是一次性分配内存,故内存的地址肯定是连续的,运行结果也证明了这一点
释放内存的两种情况:
第一种情况由于是两次不同的分配内存,所以,在释放内存的时候,我们应选择不同的区域进行释放。
第二种情况,只是连续调用两次 malloc ,所以,只需要连续两次调用 free 即可完成释放。
#include <cstdlib> #include <iostream> using namespace std; #define nWidth 3 #define nHeight 4 //内存是否连续分配问题 int main(int argc, char *argv[]) { int **p = NULL; p = (int**)malloc(nWidth*sizeof(int*)); if(p == NULL) return -1; cout<<"内存的不连续分配:"<<endl; for(int j = 0; j< nWidth; j++) { p[j] = (int*)malloc(nHeight*sizeof(int)); if(p[j] == NULL) return -1; } for(int i = 0; i < nWidth; i++) for(int j = 0; j < nHeight; j++) { printf("%p ",&p[i][j]); if(j == nHeight-1) cout<<endl; } cout<<endl; for(int j = 0; j < nWidth; j++) { free(p[j]); p[j] = NULL; } free(p); p = NULL; int **q = NULL; q = (int**)malloc(nWidth*sizeof(int*)); if(q == NULL) return -1; cout<<"内存的连续分配:"<<endl; q[0] = (int*)malloc(nWidth*nHeight*sizeof(int)); if(q[0] == NULL) { free(q); return -1; } for(int i = 1;i < nWidth; i++) q[i] = q[i-1] + nHeight; for(int i = 0; i < nWidth; i++) for(int j = 0; j < nHeight; j++) { printf("%p ",&q[i][j]); if(j == nHeight-1) cout<<endl; } cout<<endl; free(q[0]); q[0] = NULL; free(q); q = NULL; system("PAUSE"); return EXIT_SUCCESS; }
运行截图如下:
如图所示,两种分配内存的方法都能正确的分配内存,但是内存分配的空间确实不一样的。
分析:
第一种分配方法:
首先,是对每一行分配,也就是 nWidth 中的每一个进行分配,所以,我们可以看到每一行的内存都是连续的,每一个都占据四个字节
但是,为nHeight分配内存的时候,是随机的进行分配内存,所以内存的位置是不确定的,所以,出现了第一种情况
第二种分配方法:
首先,同样是为 p 分配内存,现在 p 指向一个位置
但是,在第二句中,我们需要注意,是直接在 p[0] 出分配了所有需要的内存,所以,这个时候就全部分配完了,而且由于是一次性分配内存,故内存的地址肯定是连续的,运行结果也证明了这一点
释放内存的两种情况:
第一种情况由于是两次不同的分配内存,所以,在释放内存的时候,我们应选择不同的区域进行释放。
第二种情况,只是连续调用两次 malloc ,所以,只需要连续两次调用 free 即可完成释放。
相关文章推荐
- 二维指针动态分配内存连续问题分析
- 二维指针动态分配内存连续问题分析
- 二维指针动态分配内存连续问题深入分析
- 结构体中指针赋值问题的分析及C代码示例
- android listview 连续调用 getview问题分析及解决。
- android listview 连续调用 getview问题分析及解决。
- 二维数组 指针 形参 用一个关系图解决问题
- kernel空指针引起的system_server watchdog问题分析
- 二维字符数组与二维整型数组在内存中的分配及指针的问题
- android listview 连续调用getview问题分析及解决
- 指针问题分析
- 动态分配内存的指针问题
- 令我困惑多时的二维指针分配问题总结
- android listview 连续调用 getview多次问题分析及解决
- 二维指针,二维数组,以及指向数组的指针的相关问题
- c和指针 前三章知识点以及常见的问题和程序分析
- 从一段经典错误代码说起——关于局部变量指针和函数传参的问题分析
- 结构体中指针赋值问题的分析及C代码示例
- Analyze 静态分析工具中显示 大量的CF类型指针 内存leak 问题, Core Foundation 类型指针内存泄漏
- 二维数组和二维指针的传递问题