废话不多说,直接上正题
因为二级指针和二维数组具有比较共通的特质,先引用二维数组类比二级指针
int test()
{
char str[5][50];
printf("str[1] = %d\n", sizeof(str[1])); //输出:50
return 0;
}
以上的二维数组实际上存储五个个数组大小为50的一维数组
下面我们来看一下其地址存放
int test()
{
char str[5][50];
printf("str[1] = %x\n", str[1]); //str[1] = 61fe28
printf("str[2] = %x\n", str[2]); //str[2] = 61fe5a
return 0;
}
二维数组地址存放也是连续性地存放,所以可理解为二维数组实际就是为数组的列分配一个大内存,然后对指向该列的地址进行管理,二维数组的数组名则为数组的行进行分配另一块内存,然后对指向行的地址进行管理。
借用二维数组进行类比于二级指针,二级指针的本质就是存放一级指针的地址。
int test()
{
char **str;
str = (char** )malloc( sizeof(100 * sizeof( str )) );
if( !str )
{
//创建失败
return 0;
}
}
为二级指针创建一个存放一级指针的内存,用于存放一级指针。(如下代码接上)
for(i = 0; i < i_num ; i++)
{
*(str + i) = (char* )malloc(sizeof( 10 * sizeof( char ) ));
if( !(*(str + i)) )
{
//创建失败
return 0;
}
}
如有写得不对的地方,敬请指出!