原文链接:http://www.cnblogs.com/yanlingyin/
值传递:
形参是实参的拷贝,改变形参的值并不会影响外部实参的值。从被调用函数的角度来说,值传递是单向的(实参->形参),参数的值只能传入,
不能传出。当函数内部需要修改参数,并且不希望这个改变影响调用者时,采用值传递。
指针传递:
形参为指向实参地址的指针,当对形参的指向操作时,就相当于对实参本身进行的操作
引用传递:
形参相当于是实参的“别名”,对形参的操作其实就是对实参的操作,在引用传递过程中,被调函数的形式参数虽然也作为局部变量在栈
中开辟了内存空间,但是这时存放的是由主调函数放进来的实参变量的地址。被调函数对形参的任何操作都被处理成间接寻址,即通过
栈中存放的地址访问主调函数中的实参变量。正因为如此,被调函数对形参做的任何操作都影响了主调函数中的实参变量。
理论性的就不多说,
下面的代码对此作出了细致解释(从实参,形参在内存中存放地址的角度 说明了问题的本质,容易理解 )
1 #include<iostream> 2 using namespace std; 3 //值传递 4 void change1(int n){ 5 cout<<"值传递--函数操作地址"<<&n<<endl; //显示的是拷贝的地址而不是源地址 6 n++; 7 } 8 9 //引用传递 10 void change2(int & n){ 11 cout<<"引用传递--函数操作地址"<<&n<<endl; 12 n++; 13 } 14 //指针传递 15 void change3(int *n){ 16 cout<<"指针传递--函数操作地址 "<<n<<endl; 17 *n=*n+1; 18 } 19 int main(){ 20 int n=10; 21 cout<<"实参的地址"<<&n<<endl; 22 change1(n); 23 cout<<"after change1() n="<<n<<endl; 24 change2(n); 25 cout<<"after change2() n="<<n<<endl; 26 change3(&n); 27 cout<<"after change3() n="<<n<<endl; 28 return true; 29 }