免费注册 查看新帖 |

Chinaunix

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

[C++] 谁能帮我分析一下这个程序的输出结果? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-11-16 07:17 |只看该作者 |倒序浏览
#include <iostream>
using namespace std;
class A
{
                public:
                A(){ cout<<"Ak1"; }

                A(const A&){ cout<<"Ak2"; }

                A& operator=(const A&)  {cout<<"A=";return *this;}

                ~A(){ cout<<"Ad"; }
};
A& fun( A x){cout<<"fun";return x;}

int main()
{
        A a;            
        cout<<"L1"<<endl;
        A b = fun(a);  
        cout<<"L2"<<endl;
        A& r = b;      
        cout<<"L3"<<endl;
        A t= a;
        return 0;
}

/*
  输出结果:

  AK1L1
  AK2funAdAk2L2
  L3
  Ak2AdAdAd
*/

对于输出结果有点模棱两可。尤其是为什么执行A& r = b; 时,为什么不执行任何操作?

论坛徽章:
0
2 [报告]
发表于 2009-11-16 10:35 |只看该作者
原帖由 jackietin827 于 2009-11-16 07:17 发表
#include
using namespace std;
class A
{
                public:
                A(){ cout



只是引用,不作操作

论坛徽章:
0
3 [报告]
发表于 2009-11-16 10:37 |只看该作者

回复 #1 jackietin827 的帖子

因为你把 r 定义成一个引用,它只是 b 的一个别名而已,应该是什么都不做的啊。个人观点啊。

论坛徽章:
0
4 [报告]
发表于 2009-11-16 11:36 |只看该作者

回复 #1 jackietin827 的帖子

同意三楼,引用就是一个别名而已

论坛徽章:
0
5 [报告]
发表于 2009-11-16 12:24 |只看该作者
我的输出
Ak1L1
Ak2funAk2AdL2
L3
Ak2AdAdAd

返回的时候应该先新建一个object,然后再把temporary给delete掉的吧
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP