形式参数与实际参数
形式参数(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的指向改变。从而承认了*&作为入参的处理方式。
|