浅谈一级指针与二级指针

    函数传参过程中经常使用指针,其中最常用的是以及指针与二级指针。

数组与以及指针:

type a[N] = {0};与 type* a = calloc(N,sizeof(type))很相似,明显的区别是申请的堆内存需要自己释放,这也是的用户申请的这一块内存可以在程序的整个作用域中使用成为可能。

一级指针可以理解为某种类型的数组,元素之间的地址偏移为类型的长度sizeof(type),&a[i]与&a[i+1]或者a+i 与a+i+1之间的地址偏移为类型长度。

指针数组与二级指针:

type* a[N] = {NULL};与type** a;

二级指针:该变量值是一个指针1(某一地址),且该指针1指向一个指针2,指针2是指向type类型的指针。使用过程中通常也可以形式上理解为某一种类型的指针数组。

指针数组中每一元素之间的偏移为一个指针长度(4B),与指针类型无关。即&a[i]与&a[i+1]或者a与a+1的地址偏移为固定的4B。

在涉及函数传参中有数组或者指针结构的情形下明确一点:参数的传递的值传递,这个值既可以是地址值也可以是某一类型的变量值。

使用二级指针的情形:

1.为获得某一接口内部申请的内存需要使用二级指针

type* a = NULL;

fun_xx(&a);

2.为某一接口传递指针数组参数

type* a[N] = {xxx,xxx…}

fun_xx(a);

二级指针在使用过程中容易混淆的是地址偏移,例如给func_xxx(type** a)传参:

type* a = calloc(N,sizeof(type));

for(i = 0;i< N;i++)

{

a[i] .xx= xxx;

}

func_xxx(&a);

func_xxx期望传参的是一个指针数组type*a[N],直接传入已经初始化的内存的地址&a,由于a + i(i非0)的地址是只是相对与a的地址偏移4B*i,显然是非法访问的,与申请的内存没有关系,这样调接口是失败的。

正确的用法是传入记录申请内存单元地址的指针数组:

type** tmp = {&a[i],….}

func_xxx(tmp);

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值