在调用函数时,大多数情况下,主调函数和被调用函数之间是有数据传递的关系,这就是有参函数。在定义函数时函数名后面括号中的变量名称为“形式参数”(简称“形参”,)在主调函数中调用一个函数时,函数名后面括号中的参数称为“实际参数”(简称“实参”)。
形参和实参的应用比较简单,但是有一点必须要注意,比较容易出现错误,就是实参向形参的数据传递是“值传递”,单向传递,只由实参传给形参,而不能由形参传回来给实参,在内存中,实参单元和形参单元是不同的存储单元。因此,在执行一个被调用函数时,形参的值如果发生改变,并不会改变主调函数的实参的值。下面通过一个例子来说明,请看如下的程序:
#include<stdio.h>
void main()
{
void swap(int x,int y); //声明函数,扩号里面是形参
int a,b;
scanf("%d,%d",&a,&b);
if(a<b)
swap(a,b);
printf("%d,%d\n",a,b);
}
void swap(int x,int y)
{
int temp;
temp=x;
x=y;
y=temp;
}
输入1,2,得到的输出是1,2,a,b并没有交换过来,这是因为形参的改变并不影响实参。哪有什么办法可以通过形参调用实参呢?那就要用到指针。请看如下代码:
#include<stdio.h>
void main()
{
void swap(int *p1,int *p2); //声明函数,扩号里面是形参
int a,b;
int *a_pointer,*b_pointer;
scanf("%d,%d",&a,&b);
a_pointer=&a;b_pointer=&b;
if(a<b)
swap(a_pointer,b_pointer);
printf("%d,%d\n",a,b);
}
void swap(int *p1,int *p2)
{
int temp;
temp=*p1;
*p1=*p2;
*p2=temp;
}
输入1,2,可以的到输出2,1,这是因为在调用函数时,将实参变量的值传递给形参变量,采取的依然是“值传递”方式,因此虚实结合后形参p1的值为&a,p2的值为&b,这时,p1和a_pointer都是指向a的,改变*p1,a的值就会改变,因为a的地址是唯一的,所以*a_pointer也会改变,这样形参的改变就会影响实参。
在这里再提多一点,就是指针变量的值(即地址)也不能回存的,请看下面代码:
#include<stdio.h>
void main()
{
void swap(int *p1,int *p2); //声明函数,扩号里面是形参
int a,b;
int *a_pointer,*b_pointer;
scanf("%d,%d",&a,&b);
a_pointer=&a;b_pointer=&b;
if(a<b)
swap(a_pointer,b_pointer);
printf("%d,%d\n",*a_pointer,*b_pointer);
}
void swap(int *p1,int *p2)
{
int *p;
p=p1; //注意和上面程序的区别
p1=p2;
p2=p;
}
输入1,2 ,输出也是1,2.程序的本意是调用swap函数,将a_pointer的值给p1,将b_pointer的值给p2,然后在swap中交换p1,p2,所以p1就指向b,p2就指向a,回传给实参后a_pointer指向b,b_pointer指向a,通过printf("%d,%d\n",*a_pointer,*b_pointer);输出b,a,但是即使是地址也是不能回存的,请注意指针和上面程序的不同之处。