首先我们来学习实参,什么是实参呢?
实际参数简称“实参”。
在调用有参函数时,函数名后面括号中的参数称为“实参”,是我们真实传给函数的参数,实参可以是:常量、变量、表达式、函数等。
无论实参是何种类型的量,在进行函数调用时,它们都必须有确定的值,以便把这些值传送给形参。
下面我们写个代码来帮助大家理解:
#include
int add(int x, int y)
{
return x + y;
}
int main()
{
int a = 20;
int b = 30;
int ret1 = add(20, 30);
printf("%d\n", ret1);
int ret2 = add(a, b);
printf("%d\n", ret2);
int ret3 = add(a + b, a - b);
printf("%d\n", ret3);
int ret4 = add(add(2, 3), 5);
printf("%d\n", ret4);
return 0;
}
那什么是形式参数呢?
形式参数是指函数名后括号中的变量,因为形式参数只有在函数被调用的过程中才实例化(分配内存单元),所以叫形式参数。
形式参数当函数调用完成之后就自动销毁了。因此形式参数只在函数中有效。
还来看上面的代码:
#include
int add(int x, int y)
{
return x + y;
}
int main()
{
int a = 20;
int b = 30;
//printf("%d %d", x, y);
int ret1 = add(20, 30);
printf("%d\n", ret1);
int ret2 = add(a, b);
printf("%d\n", ret2);
int ret3 = add(a + b, a - b);
printf("%d\n", ret3);
int ret4 = add(add(2, 3), 5);
printf("%d\n", ret4);
return 0;
}
1.形参只在函数中有效:
2.形参在函数调用过程中才实例化(分配内存单元)
函数调用之前,形参还未创建
函数调用过程中,形参才被实例化
函数调用结束,形参生命周期结束,被销毁
了解了什么是函数的形参和实参,那两者之间有什么关系呢?
他们的关系是:
形参实例化之后其实相当于实参的一份临时拷贝。
这里我们对函数的实参和形参进行分析:
我们来尝试写一个函数交换两个整形变量的内容。
#include
//实现成函数,但是不能完成任务
void Swap1(int x, int y) {
int tmp = 0;
tmp = x;
x = y;
y = tmp;
}
int main()
{
int num1 = 1;
int num2 = 2;
Swap1(num1, num2);
printf("Swap1::num1 = %d num2 = %d\n", num1, num2);
return 0;
}
函数swap1用x,y接收了num1,num2,并把x,y进行了交换,但是我们打印出来的num1,num2并没有交换,为啥呢?
这是因为在函数调用时,形参x,y是实参num1,num2的一份临时拷贝,形参和实参并没有建立真正意义上的联系,形参x,y是两个独立的变量,和实参num1,num2分别占用不同的内存空间,在这里,形参和实参只是数值相同罢了.
所以,交换形参x,y,并不会对实参num1,num2产生影响!!!
在这里,我们如果想要达到交换实参的目的,需要进行传址调用,这个后面我们会详细给大家讲解,现在可以先简单了解一下:
所谓传址,就是num1,num2的地址作为参数传过去,当然我们就需要两个整形指针去接收,然后,我们在函数内部,就可以通过这两个指针找到num1,num2,对它们进行交换.
接下来,我们就用传址调用的方法来实现一下函数:
#include
//正确的版本
void Swap2(int* px, int* py) {
int tmp = 0;
tmp = *px;
*px = *py;
*py = tmp;
}
int main()
{
int num1 = 1;
int num2 = 2;
Swap2(&num1, &num2);
printf("Swap2::num1 = %d num2 = %d\n", num1, num2);
return 0;
}
总之,我们最后得到的结论就是,函数实参与形参的关系就是:
形参实例化之后其实相当于实参的一份临时拷贝。
以上就是对函数参数的介绍,欢迎大家指正!!!