// Reference.cpp // Different between pass by Reference and pass between value #include <iostream> using namespace std; void f(int&, int); main() { int i = 0, j = 0; cout << "i= " << i << "/t" << "j= " << j << endl; cout << "&i= " << &i << "/t" << "&j= " << &j << endl; f(i, j); cout << "i= " << i << "/t" << "j= " << j << endl; // wait(); return 0; } void f(int& x, int y) { cout << "x= " << x << "/t" << "y= " << y << endl; cout << "&x= " << &x << "/t" << "&y= " << &y << endl; x++; y++; cout << "x= " << x << "/t" << "y= " << y << endl; }
屏幕输出:
i= 0 j= 0
&i= 0x22ff6c &j= 0x22ff68
x= 0 y= 0
&x= 0x22ff6c &y= 0x22ff44
x= 1 y= 1
i= 1 j= 0
可以看到给函数 f() "传引用(pass by reference)"和"传值(pass by value)"在使用上类似,但实际中有很大区别:
"传值"传递的是原始变量 j 的一份拷贝 y,编译器为新的拷贝 y 重新分配了内存空间,因此本例中变量 j 和 变量 y 有不同的内存地址.对函数 f() 体内 y 的附新值,不会影响函数 f() 体外 j 的值.
"传引用"传递的是变量 i 的地址,并没有额外分配新的内存空间.x 就相当于 i 在 f() 体内的一个别名(我的理解),x 同 i
使用相同的地址空间,使用 x 就相当于引用了 i 的值,显然对 f() 体内 x 赋新值,就会影响到函数 f() 体外 i 的值.这点其实也就是我们使用"传引用"的目的之一,能影响 "outer object"
.
有的时候你希望引用函数如 f() 不能修改被引用的变量如 i,那么可以这样定义函数:
void f(const int& x, int y)
这样的话,如果你还是在 f() 里使用 x++,那么编译时就会提示你引用的是一个只读变量.
/* Reference.c */ /* Different between pass by Reference and pass between value */ #include <stdio.h> void f(int& i, int j); main() { int i = 0, j = 0; printf("&i=%x, &j=%x\n", &i, &j); f(i, j); printf("i=%d, j=%d\n", i, j); return 0; } void f(int& i, int j) { printf("&i=%x, &j=%x\n", &i, &j); i++; j++; }
这是一种良好的编程习惯, 比起传值调用,优点在于不需要额外分配内存空间.