来源:http://blog.csdn.net/thefutureisour/article/details/7653059
这个也是牛人
参数的传递就是用实参初始化对应的形参。
非引用形参:
基本的情况:复制实参的值。函数并没有访问调用函数所传递的实参本身,所以不会改变实参的值。
- void swap(int x, int y)
- {
- int tmp;
- tmp = x;
- x = y;
- y = tmp;
- }
- int main()
- {
- int a = 1,b = 2;
- cout<<"a = "<<a<<"\t"<<"b = "<<b<<endl;
- int* pa = &a;
- int* pb = &b;
- swap(a,b);
- cout<<"a = "<<a<<"\t"<<"b = "<<b<<endl;
- return 0;
- }
指针形参:此时将复制实参的指针:形参的改变不会引起实参的改变,但是形参指向的内容可以发生变化。
- void swap(int *px, int *py)
- {
- int tmp;
- tmp = *px;
- *px = *py;
- *py = tmp;
- }
- int main()
- {
- int a = 1,b = 2;
- cout<<"a = "<<a<<"\t"<<"b = "<<b<<endl;
- int *pa = &a;
- int *pb = &b;
- swap(pa,pb);
- cout<<"a = "<<a<<"\t"<<"b = "<<b<<endl;
- return 0;
- }
程序中,虽然pa始终指向a,pb始终指向b,但是a与b的值已发生了交换。
const形参:const实参可以传递给非const形参,因为初始化的复制规则:可以用const对象给非const对象复制
- int plus(int x,int y)
- {
- return x+y;
- }
- int main()
- {
- const int a = 1;
- const int b = 2;
- int c = plus(a,b);
- cout<<a<<"+"<<b<<"结果为"<<c<<endl;
- return 0;
- }
当然,使用const实参初始化const形参肯定是没有问题的。
- int plus(const int x,const int y)
- {
- return x+y;
- }
- int main()
- {
- const int a = 1;
- const int b = 2;
- int c = plus(a,b);
- cout<<a<<"+"<<b<<"结果为"<<c<<endl;
- return 0;
- }
反之,非const对象也可以传递给const形参,只要在程序中不改变形参的值即可:
- int plus(const int x,const int y)
- {
- return x+y;
- }
- int main()
- {
- int a = 1;
- int b = 2;
- int c = plus(a,b);
- cout<<a<<"+"<<b<<"结果为"<<c<<endl;
- return 0;
- }
但是,如果你想在程序中修改形参的值,就会报错:
- int plus(const int x,const int y)
- {
- return (++x)+(++y);
- }
编译无法通过。
复制实参的不适合的情况:
1.需要在函数中修改实参的值
2.没有办法实现参数的复制(比如数组)
3.当使用大型对象作为参数传递时,复制对象付出的代价太大。