C语言:指针作为函数的入参

形式参数与实际参数

形式参数(parameter)出现在函数定义中,他们以假名字来表示函数调用时提供的值
实际参数(argument)是出现在函数调用中的表达式。

在C语言在,实际参数是通过 值传递 的;调用函数时,计算出每个实际参数的值并且把它赋值给相应的形式参数。在函数执行过程中,对形式参数的改变不会影响实际参数的值。从效果上来看,每个形式参数的行为好像是把变量初始化为与之匹配的实际参数的值

形式参数的修改不会影响到相应的实际参数,那么可以把形式参数作为函数内的变量来使用,因此可以减少真正需要的变量的数量。

指针作为实际参数

void decompose(float x,int int_part,float frac_part)
{
	int_part = (int)x,
	frac_part = x - int_part;
}

上述函数虽然在函数内把x的整数部分分配给int_part,把x的小数部分分配给frac_part,但是调用后无法输出int_part frac_part,因为两者是形式参数,只传递值,不改变给它赋值的实际参数的值。
为了解决上述问题,我们可以通过把形式参数int_part 和 frac_part声明成指针的方法来修改decompose函数:

void decompose(float x,int *int_part, float *frac_part){
	*int_part = (int) x;
	*frac_part = x - int_part;
}

其函数的原型下面两种形式都可以

void decompose(float, int *,float *);
void decompose(float x,int *int_part,float *frac_part);

函数调用时将地址作为实际参数

#define 3.1415926 pi
int i;
float j;
decompose(pi, &i, &j);

指针的地址作为实际参数

在对链表的数据结构操作时,经常需要修改指针的指向,这就需要将指针的指针作为函数的入参,然而在考研书中,函数的入参往往写作指针的地址,在此记录一下这种用法。并用下面的代码简单验证一下可行性,原理等待请教

#include "stdio.h"
bool freep(int *&p){
	p = NULL;
}
int main(){
	int a = 1;
	int *p = &a;
	printf("%d\n",*p);
	freep(p);
	if(p == NULL){
		printf("sucessfully rectify pointing to NULL"); 
	}
	return 0;
}

输出结果
在这里插入图片描述
由此可以看出,指针确实实现了从a到NULL的指向改变。从而承认了*&作为入参的处理方式。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值