二级指针申请内存操作–c语言实现

  • Post author:
  • Post category:其他


应对二维数据,不得不动态申请两维内存来存储不确定大小的数据。

例题:设计n长的数组,每个数组能存储10个字节的数据。


char* *arr = malloc(n*sizeof(char *));  //申请n个指针长度的空间用于存放指针地址

这个时候就可以将二级指针排上用场,二级指针可以这样理解:”char*”作为一种数据类型—长度为8个字节指针类型,再加一个“*” 是为了表示成数组,因为通常我们用char *a;a[0],a[1]中的a也能被我们看成数组,这里的arr也是数组,arr[0],arr[1]存放的都是指针。


当然这个时候的arr[0],arr[1]都是空的NULL,这个时候就得给它分配内存了,如下:


int i = 0;

for(i =0;i<n;i++)

{


arr[i] = malloc(10);      //为每个指针地址申请10个字节的空间

}


很明显,我们能看到二级指针的用法其实和数组很像,它其实就是一个数组—指针数组,一个专门来存放指针的数组。



版权声明:本文为u011721450原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。