C语言中的内存分配深入
这里不讲解c语言的内存分配怎么使用,只说要注意的问题。我们借用一下c++的,先看一个c++的内存分配:
#include <iostream>
using namespace std;
struct cpp_Format
{
float pData[5];
};
cpp_Format ** c_pp;
int main()
{
int i;
c_pp = new cpp_Format* [10];
for (i=0; i < 10; i++)
c_pp[i] = new cpp_Format[20];
for (i=0; i < 10; ++i)
delete[] c_pp[i];
delete[] c_pp;
return 0;
}
那我们模仿一下,把他做成c语言的样子:
#include <stdlib.h>
#include <stdio.h>
int main( void )
{
int *p1 = (int *)malloc(10);
free(p1);
int **p = NULL;
p = (int **)malloc(10);
for (int i = 0; i < 10; i++) {
p[i] = (int *)malloc(10);
}
for (int i = 0; i < 10; i++) {
free(p[i]);
}
free(p);
}
问题就出来,上面的程序编译起来没有问题,运行起来问题就大了。其实我们要知道,c++里面比如:
c_pp = new cpp_Format* [10];
这个10表示分配10个cpp_Format对象需要的空间。
再看看
int *p1 = (int *)malloc(10)
真正理解malloc的就晓得,这个不是分配10个对象空间,仅仅是分配10个字节。
那么10字节分配之后p1怎么用,从p[0]到p[9]?明显不是,一个int占4个字节,10个就是两个半int,哈哈这个就不好用了,p[0]到p[1.5]?无语!
再看:
int **p = NULL;
p = (int **)malloc(10);
for (int i = 0; i < 10; i++) {
p[i] = (int *)malloc(10);
}
这个东西就有意思了,**p是10个字节,一个int *占4个字节,那么同样10/4之后就肯定没有10个分配好的指针,之所以编译不出错,是因为指针偏移不会越界。
p[i] = (int *)malloc(10);
这个也是问题,用p[i][2]有多用p[i][3]又不够!
其实解决方法很简单:不要偷懒!
修改如下:
#include <stdlib.h>
#include <stdio.h>
int main( void )
{
int *p1 = (int *)malloc(10 * sizeof(int) );
free(p1);
int **p = NULL;
p = (int **)malloc(10* sizeof(int *));
for (int i = 0; i < 10; i++) {
p[i] = (int *)malloc(10 * sizeof(int ) );
}
for (int i = 0; i < 10; i++) {
free(p[i]);
}
free(p);
}
C和c++内存分配那个更好,不好说,实现的问题。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/ztz0223/archive/2008/04/17/2299397.aspx