一、函数未被调用前,函数的形参并不占有实际的内存空间,也没有被赋值。只有在被调用的时候,才被赋值。函数参数传递指的就是形参和实参想结合的过程。
二、函数参数传递存在两种形式:
1、值传递:
即函数在发生调用时,给形参分配内存空间,直接以实参的值初始化形参。函数被赋值后,实参和形参即没有关系,形参的改变不影响到实参。
函数传递是实参的值,是单向传递过程。形参值的改变对实参不起作用。
2、引用传递:把引用作为形参,在函数调用时发生的参数传递,成为引用传递。
通过引用名与通过被引用的变量名访问变量的效果是一样的。
形参的初始化不在类型说明时进行,而是在调用函数表达式时才为形参分配内存空间,同时用实参来初始化形参。这样引用的类型就是通过形参实参想结合,成为了实参的一个别名,对形参的任何操作都会作用于实参
注意事项:1、声明一个引用时,必须同时对他进行初始化,使他指向一个已存在的对象。
2、一旦一个引用被初始化后,就不能指向其他对象。也就是说,一个引用,从他诞生之时起,必须确定是哪个变量的别名,不能另作它用。
三、引用传递和值传递的区别只是函数的形参写法不同。主调函数的调用表达式是完全一样的。
附代码
#include <iostream>
#include <iomanip>
using namespace std;
void fiddle(int in1, int &in2);
void main()
{
int count = 7, index = 12;
cout << "The values are ";
cout<<setw(5)<<count;
cout<<setw(5)<<index<<endl;
fiddle(count, index);
cout << "The values are ";
cout<<setw(5)<<count;
cout<<setw(5)<<index<<endl;
}
void fiddle(int in1, int &in2)
{
in1 = in1 + 100;
in2 = in2 + 100;
cout << "The values are ";
cout<<setw(5)<<in1;
cout<<setw(5)<<in2<<endl;
}