怎么用malloc开辟二维数组
1.利用指针数组
每一行地址连续,但不能保证上一行最后一个地址与下一行首地址连续
如下图,展示了如果用指针数组开辟二维数组
指针数组开辟二维数组的代码:
#incldue<stdio.h>
#incldue<stdilb.h>
int main()
{
int **p = (int**)malloc(3*sizeof(int*)); //竖的数组申请好了
for(int i=0;i<0;i++)
{
p[i] = (int*)malloc(4 * sizeof(int)); //横的数组申请好了
}
for(int i=0;i<3;i++)
{
for(int j=0;j<4;j++)
{
printf("%p\n",&p[i][]); //
}
}
return 0;
}
虽然我们可以用指针数组开辟二维数组,但是这种方式也是有缺陷的,如:和正常的二维数组不同,不能保证地址连续,而且最关键的是很容易造成内存泄漏,就像上面开辟的二维数组,实际上开辟了四块动态内存,就需要释放四次,很麻烦并且容易忘记&#