应对二维数据,不得不动态申请两维内存来存储不确定大小的数据。
例题:设计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 版权协议,转载请附上原文出处链接和本声明。