一、问题
在调⽤函数的时候,调⽤函数和被调⽤函数之间基本都会发⽣数据传递关系,这就要⽤到有参函数,⽽不传递数据的就需要⽆参函数。这样必然涉及形参和实参的概念,那么究竟什么是形参?什么又是实参呢?如何应⽤?
二、解答
定义函数 int test(int x,int y) 时,函数名后⾯括号中的变量名就是“形式参数”(简称形参)。实际参数就是在主调函数中调⽤⼀个函数时,函数名后⾯括号中的参数。
形参出现在函数定义中,在整个函数体内都可以使⽤,离开该函数则不能使⽤。实参出现在主调函数中,进⼊被调函数后,实参变量也不能使⽤。
形参和实参的功能是进⾏数据传送。发⽣函数调⽤时,主调函数把实参的值传送给被调函数的形参,从⽽实现主调函数向被调函数的数据传送。
函数的形参和实参具有以下特点:
(1)形参变量只有在被调⽤时才分配内存单元,在调⽤结束时将释放所分配的内存单元。因此,形参只在函数内部有效。函数调⽤结束返回主调函数后,就不能再使⽤该形参变量了。
(2)实参可以是常量、变量、表达式、函数等。⽆论实参是何种类型的量,在进⾏函数调⽤之前,每个实参都必须具有确定的值,以便把这些值传递给形参(如果形参是数组名,则传递的是数组⾸地址⽽不是数组的值,这点会在后⾯提到)。因此,应预先⽤赋值、输⼊等⽅法使实参获得确定值。
(3)实参和形参的类型应相同或赋值兼容。例如下⾯的形式。
#include <stdio.h>
int test(int x, int y)
{
int z;
z = x * y;
return z;
}
int main()
{
float a, b, c;
printf("please input a and b:\n");
scanf("%f,%f", &a, &b);
c = test(a, b);
printf("the product is:%f\n", c);
}
输出结果如下:
please input a and b:
2.5,3.8
the product is:6.000000
通过输出结果会发现 2.5 与 3.8 的积是 6 ,显然这个结果不正确。这是为什么呢?因为形参的数据类型是基本整型,⽽实参的数据类型是单精度型,实参和形参的数据类型不同, 所以最终结果产⽣了误差。
(4)C语⾔规定,实参变量对形参变量的数值传递是单向传递,即只能由实参传给形参,⽽不能由形参再传给实参。下⾯的程序可以说明这个问题。
计算函数 f(x) 的值代码如下。
#include <stdio.h>
int f(int n)
{
int i;
if (n > 0)
n = n + 10;
else
{
if (n < 0)
{
n = n + 20;
}
else
{
n = 100;
}
}
printf("n=%d\n", n);
return n;
}
int main()
{
int n;
printf("input number\n");
scanf("%d", &n);
f(n);
return 0;
}
程序运⾏结果如如下:
input number
25
n=35
本程序中定义了⼀个函数 f( ) ,该函数的功能是根据输⼊数的正负值不同与不同的数相加求和。在主函数中输⼊ n 值,并作为实参,在调⽤时传送给 f( ) 函数的形参n。
在函数 f( ) 中先⽤ printf 语句输出了⼀次n值,这个n值是形参最后取得的 n 值。在主函数中再⽤ printf 语句输出⼀次 n 值,这个 n 值是实参 n 的值。从运⾏情况看,输⼊的 n 值为15,即实参 n 的值为15。把此值传给函数 f( ) 时,形参 n 的初值也为15。
在执⾏函数过程中,形参 n 的值变为25。返回主函数之后,输出实参 n 的值仍为15。由此可见,实参的值不随形参的变化⽽变化。有⼀点要说明的是,这⾥的主函数和函数 f( ) 中⽤到的 n 应加以区别,这两个 n 不是同⼀个 n ,它们各⾃作⽤的范围不同。
三、总结
对于到底是使⽤有参函数还是使⽤⽆参函数,需要根据函数所要实现的功能来决定。