二级指针在堆中的空间结构

在堆中创建的空间如下:

malloc(sizeof (int)*4)                                      //如果是整形的空间应该用什么变量来接收呢?

int * pArray = malloc(sizeof(int)*4)           //用int * 来接收整形的

malloc(sizeof (int *)*5)                                //用二级指针int **  来接收

int** pArray = malloc(sizeof (int *)*5) 

                                                pArray

int *int*int*int*int*
0x010x020x030x040x05

 每一个地址对应一个参数:

空间结构

ox01 10
0x0220
0x0330
0x0440
0x0550

//打印数组

voidprintArray(int ** pArray, int len)

{

        for(int i = 0; i<len; i++)

             {

                        print("%d\n",*pArray[i]);

            }

}

void test01()

{

        int** pArray = malloc(sizeof (int *)*5) 

                //在栈上创建5个数据

                int num1= 10;

                int num2= 20;

                int num3= 30;

                 int num4= 40;

                 int num5= 50;

//建立关系:

                pArray[0] = &num1;

                pArray[1] = &num2;

                pArray[2] = &num3;

                pArray[3] = &num4;

                pArray[4] = &num5;

//打印数组

  printfArray(pArray,5);

//堆中的数据要手动开辟,手动释放

                      if(pArray! == NULL)

                        {

                               free(pArray);

                                pArray=NULL;

                          }

}

int main()

{

        test01();

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值