int age = 10; int &ref = age; ref = 20; // 此处相当于修改age,引用相当于别名
常引用1、引用在定义的时候就必须初始化,一旦指向了某个变量,就不可再改变(指针可以修改指向)
2、优点:比指针更安全,函数返回值可以被赋值
3、引用的本质就是指针,只是编译器削弱了它的功能,所以引用就是弱化了的指针
C++函数中返回引用和返回值的区别1、 const必须写在&符号的左边,才能算是常引用
2、常引用可以指向临时数据(常量、表达式、函数返回值) const int& p = 30;
3、常引用作为函数参数,既可以接收const实参,也可以接收非const实参
4、可以和非const引用构成重载
5、常引用可以指向不同类型的数据 int age= 10; const double& rAge = age;
int& at() { return m_data_; }
int at() { return m_data_; }
上面两个函数,第一个返回值是 int 的引用 int&,第二个返回值是 int,二者的区别是什么呢?我们先用一个语句 const int& a = mymay.at(); 来分别调用一次上面两个函数。
说明一下函数返回时,如果不是返回一个变量的引用,则一定会生成一个临时变量所以结论就是:
1、返回值为引用型(int& )的时候,返回的是地址,因为这里用的是 int& a=mymay.at(); ,所以 a 和 m_data_指的是同一块地址(由寄存器 eax 传回的 5879712)。
2、返回值不是引用型(int)的时候,返回的是一个数值。这个时候就很有意思了,编译器是先将这个数值放入一个内存中(上面例子中,该内存地址为 ebp-24h),再把这个地址付给 a,此时的 a 代表的地址是 ebp-24h,和 m_data_代表的地址不一样。
3、综上两点可以看出,当返回的值不是引用型时,编译器会专门给返回值分配出一块内存(例子中为 ebp-24h)。
看下面的函数,返回的是 t 而不是 & t,所以一定会有临时变量产生。
T function1(){ T t(0); return t; } T x=function1();
这里的过程是:
1. 创建命名对象 t
2. 拷贝构造一个无名的临时对象,并返回这个临时对象
3. 由临时对象拷贝构造对象 x
4.T x=function1 (); 这句语句结束时,析构临时对象。
这里一共生成了 3 个对象,一个命名对象 t,一个临时对象作为返回值,一个命名对象 x。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)