废话不多说,直接上正题
因为二级指针和二维数组具有比较共通的特质,先引用二维数组类比二级指针
int test() { char str[5][50]; printf("str[1] = %dn", sizeof(str[1])); //输出:50 return 0; }
以上的二维数组实际上存储五个个数组大小为50的一维数组
下面我们来看一下其地址存放
int test() { char str[5][50]; printf("str[1] = %xn", str[1]); //str[1] = 61fe28 printf("str[2] = %xn", 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; } }
如有写得不对的地方,敬请指出!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)