下面以二维数组的动态分配内存为例。
extern int x,y;//x和y是在其他位置定义好的变量,用于指定数组的行和列
for嵌套循环法
-
申请
int **a=(int **)calloc(x,sizeof(int*));//先申请主数组(每个元素都是一维数组) for(int i=0;i<x;i++){ *(a+i)=(int *)calloc(y,sizeof(int));//再申请每个一维数组 }
-
访问(以打印为例)
- 通过解引用指针访问
for(int j=0;j<x;j++){ for(int i=0;i<y;i++){ printf("%d\t",*(*(a+j)+i)); } printf("\n"); }
- 通过变地址运算符访问
for(int j=0;j<x;j++){ for(int i=0;i<y;i++){ printf("%d\t",a[j][i]); } printf("\n"); }
-
释放
for(int i=0;i<x;i++){ free(*(a+i));//顺次释放每一个一维数组 } free(a);//再释放主数组
数组指针法
注:不要将数组指针和指针数组互相混淆,它们只是在名字上类似,但却是截然不同的东西,可类比指针函数和函数指针进行理解,具体可参考我写的函数指针和指针函数的博客。
-
申请
int (*a)[y]=(int (*)[y])malloc(x*y*sizeof(int));//数组指针指向了一个有y个元素的数组,相当于指定了列
使用和for循环嵌套相同。
-
释放
free(a);