对二级指针分配内存及理解

对二级指针分配内存及理解,第1张

对二级指针分配内存及理解

废话不多说,直接上正题

因为二级指针和二维数组具有比较共通的特质,先引用二维数组类比二级指针

    
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;
        }
    }

如有写得不对的地方,敬请指出!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5703153.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-17
下一篇 2022-12-17

发表评论

登录后才能评论

评论列表(0条)

保存