免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2415 | 回复: 6
打印 上一主题 下一主题

[C++] const 引用与临时变量的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-05-14 10:57 |只看该作者 |倒序浏览
本帖最后由 Frahm 于 2013-05-14 10:59 编辑
  1. const int& fwd(const int& i) {
  2.   return i;
  3. }
  4. const Foo& fwd(const Foo& f) {
  5.   return f;
  6. }
  7. int main() {
  8.   const int& ir = fwd(4); //1
  9.   const Foo& fr = fwd(Foo());//2
  10. }
复制代码
看上面的2,fr应该是dangling reference, ir也是吗?在1的地方传入的参数4是传拷贝还是引用呢?还有那个4的有效lifetime是什么?

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
2 [报告]
发表于 2013-05-14 15:43 |只看该作者
我的理解:引用的实现也是通过指针,返回临时对象的const 引用,虽然临时对象销毁了,但是引用通过地址取到“对象”
楼主可以参考下面代码调试:
  1. #include <iostream>  
  2. #include <fstream>  
  3. #include <string>  
  4. #include <cstdio>
  5. #include <cstring>
  6. using namespace std;  
  7.   
  8. class Foo{
  9. public:
  10.         Foo():n(321){ printf("Foo(): %d %p\n", n, this); }
  11.         ~Foo(){ n = 0; std::cout << "~Foo()\n"; }
  12.         void *display() const { printf("Foo().display(): %d %p\n", n, this); return (void*)this; }
  13. private:
  14.         int n;
  15. };

  16. const int& fwd(const int& i) {
  17.         return i;
  18. }

  19. const Foo& fwd(const Foo& f) {
  20.         return f;
  21. }

  22. int main() {
  23.         const int& ir = fwd(4); //1
  24.         const Foo& fr = fwd(Foo());//2
  25.         Foo *pf = (Foo*)fr.display();
  26.         new (pf)Foo();
  27.         fr.display();
  28.         getchar();
  29. }
复制代码

论坛徽章:
0
3 [报告]
发表于 2013-05-14 16:11 |只看该作者
回复 3# cokeboL

输出:
Foo(): 321 006DF850
~Foo()
Foo().display(): 0 006DF850
Foo(): 321 006DF850
Foo().display(): 321 006DF850

看得出来,fr是dangling reference,我想知道关于ir是怎样的?

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
4 [报告]
发表于 2013-05-14 16:44 |只看该作者
回复 4# Frahm

这个帖子或许有点帮助。。。我阵亡了,语法真要命,我不搞了,哈哈哈

    http://www.cnblogs.com/soaliap/archive/2012/11/19/2777131.html

论坛徽章:
0
5 [报告]
发表于 2013-05-14 19:34 |只看该作者
回复 5# cokeboL


    那个讲的是右值引用,我这个问题不涉及c++11,不过还是多谢。

论坛徽章:
0
6 [报告]
发表于 2013-05-14 21:55 |只看该作者
本帖最后由 rosynirvana 于 2013-05-14 22:19 编辑

c++ primer 6.2
Parameter initialization works the same way as variable initialization.
When a parameter is a reference, we say that its corresponding argument is "passed by reference" of theat the function is "called by reference".
所以是传参


下面引用的是c++标准,网上找的2005-10-19的那份草稿

literal没有lifetime的概念。
const int& foo= 42;
实际上是 int temp =42; const int& foo= temp; (8.5.3)
temp这个临时变量有lifetime,是
A temporary bound to a reference parameter in a function call (5.2.2) persists until the completion of the full expression containing the call. (12.2.5)

同样12.2.5
A temporary bound to a reference member in a constructor’s ctor-initializer (12.6.2) persists until the constructor exits.
可以知道1的临时变量在构造函数返回后销毁

不过用引用来初始化引用正确吗?我自己都要被绕晕了…退散了…

论坛徽章:
0
7 [报告]
发表于 2013-05-14 22:28 |只看该作者
本帖最后由 Frahm 于 2013-05-14 22:31 编辑

回复 7# rosynirvana


    也就是4被传入的时候是拷贝的?所以ir也引用到了过期的int?
可以这样想,返回类型是const T&,所以也就是一个const T& 绑定到返回值上,接收返回值的一方正是const T&类型,所以绑定到了函数内的返回值上了,不过在语句执行完就已经被析构了,所以是dangling reference
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP