c/c++ 中的传值调用和传引用

// 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++;
}
 


 

这是一种良好的编程习惯, 比起传值调用,优点在于不需要额外分配内存空间.

猜你喜欢

转载自socol.iteye.com/blog/1570810