对函数入口指针的理解

指针做函数入口参数,这里就相当于形参跟实参的问题(局部变量,全局变量),

typedef struct
{
	uint8_t 			*pSendBuf[10];//申请空间用,指针数组
}Ram_t;
Ram_t testp_t;
uint8_t bufData[20]={0};
static uint8_t* newRam_p(uint8_t *p,uint8_t *data,uint16_t len)
{
	//这里输入的指针是未赋值的空指针,所以申请的空间只能给p(此时的P并没有实例,因为传入的指针本就是空,这里相当于局部指针变量了)
	p=(uint8_t*)malloc(len*sizeof(uint8_t));
	memcpy(p,data,len);
	*pLen=len;
	return p;//若通过返回所申请的空间,是可以把此临时指针P给带出去的,但是例程中,testp_t->pBuf[0]本身为空指针,所以无法得到申请的地址。
}
static int16_t newRam_pt(Ram_t *pt,uint8_t *data,uint16_t len)
{
	//这里的pt是全部变量,所以是存在实例的,pt表示的就是入口参数所传入的全局变量的地址,
	pt->pBuf[0]=(uint8_t*)malloc(len*sizeof(uint8_t));//举例用buf[0],这里是赋值给实例结构体中的某个指针指定的空间,可以成立
	if(pt->pBuf[0] == NULL)
        return FULL_ERR;	
	memcpy(pt->pBuf[0],data,len);
	return NONE_ERR;
}
void main()
{
	//这里传入的testp_t->pBuf[0]虽然是全局变量,但是到了函数内部此指针并						未能找到,
	newRam_p(testp_t->pBuf[0],bufData,10);
	//这里传入的testp_t是全局变量,需要赋值的指针在其内部,属于一个变量,在函数内部可以根据实例找到
	newRam_pt(&testp_t,data,10);
}

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值