多维数组的动态分配内存

下面以二维数组的动态分配内存为例。

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);
    
posted @ 2024-02-17 18:19  椰萝Yerosius  阅读(31)  评论(0)    收藏  举报  来源