| 编程中国 | 业界新闻 | 技术文章 | 视频教程 | 下载频道 | 程序源码 | 个人空间 | 编程论坛
全能ASP/PHP/ASP.NET主机,支持月付专业 MSSQL 数据库空间,支持月付专业 MySQL 数据库空间,支持月付买域名,送MP3、MP4
高端软件开发 = 年薪十万不是梦赛孚耐:软件保护加密专家身份认证令牌USB KEY买空间,免费送域名(厦门中资源)
共有 264 人关注过本帖
标题:返回局部对象的引用,小弟遇到问题了!求助
收藏  订阅  推荐  打印 
独孤剑魔
Rank: 2
等级:注册会员
帖子:99
积分:1216
注册:2008-8-5
返回局部对象的引用,小弟遇到问题了!求助

#include<iostream>
#include<string>
#include<cstdlib>
using namespace std;
const string &ret(string &str1,string &str2)
{
    cout<<"***************************"<<endl;
    cout<<"str1="<<&str1<<endl;
    cout<<"str2="<<&str2<<endl;
    cout<<"str1="<<str1<<endl;
    cout<<"str2="<<str2<<endl;
    if(str1.size()<str2.size())
    {
        str1=str2;
        return str1;
    }
    else
    {
        str2=str1;
        return str2;
    }
}
//测试返回函数内声明对象的引用
int &ret(const int &i,const int &j)
{
    if(i>j)
    {
        int k=i;
        cout<<"&k="<<&k<<"\t"<<k<<endl;
        return k;
    }
    else
    {
        int k=j;
        cout<<"&k="<<&k<<"\t"<<k<<endl;
        return k;
    }
}
string &ret(const string &s)
{
    string str = s;
    return str;
}
int main()
{
    string str1="abcdefg";
    string str2="abcefghigklmn";
    cout<<"str1="<<&str1<<endl;
    cout<<"str2="<<&str2<<endl;
    cout<<"str1="<<str1<<endl;
    cout<<"str2="<<str2<<endl;
    string str3 = ret(str1,str2);
    cout<<"*************************"<<endl;
    cout<<"str1="<<&str1<<endl;
    cout<<"str2="<<&str2<<endl;
    cout<<"str1="<<str1<<endl;
    cout<<"str2="<<str2<<endl;
    cout<<"*************************"<<endl;
    cout<<"str3="<<&str3<<endl;
    cout<<"str3="<<str3<<endl;
    int i=10,j=15;
    int h = ret(i,j);//调用函数,因为返回的是函数中的局部对象的引用,函数执行完时会释放,按说运行时会导致错误。但是此行并没有运行错误?是什么原因啊?
    string aa = "dada";
    string gg = ret(aa);//调用函数,因为返回的是函数中的局部对象的引用,函数执行完时会释放,运行时导致错误。此行就在运行时正常出现错误了,请高手解释下。
    return 0;
}
请各位高手讲讲我注释的第一行,为什么此引用没导致运行时出错。

[ 本帖最后由 独孤剑魔 于 2008-9-16 17:04 编辑 ]
搜索更多相关主题的帖子: 局部  对象  
2008-9-16 16:51
独孤剑魔
Rank: 2
等级:注册会员
帖子:99
积分:1216
注册:2008-8-5

还是上面那个问题,string &ret(const string& s)函数明明需要返回一个string 对象,在main函数中,如果将
string gg = ret(aa)--改为ret(aa);运行时就不会出错,在java中我记得是不可以的,因为需要有相应的类型对象来接受return返回的对象,但是c++中,这样写编译与运行都不会出错了,求教高手把握第一问于第二问一起回答。谢谢了
问题整理:
问题1:请看1楼代码段,加注释地方。
问题2:2楼,上面的那些话,谢谢。
2008-9-16 17:03
独孤剑魔
Rank: 2
等级:注册会员
帖子:99
积分:1216
注册:2008-8-5

为什么没人回答啊???
2008-9-16 22:47
dsj_2
Rank: 1
等级:新手上路
帖子:5
积分:148
注册:2008-9-7

我来回答,这是因为C++中使用临时复制对象来传值的缘故.例如: int h=ret(i,j); 虽然返回值k是局部对象,但是return k;时C++会用一个临时复制对象来保存k的值,接着k的生存期结束,然后临时对象的值被赋给h,最后临时复制对象的生存期结束!
2008-9-17 06:25
zzt_428
Rank: 2
来自:南京师范大学
等级:注册会员
威望:1
帖子:156
积分:1740
注册:2008-7-6
浅见

我个人的观点是:
String 类内部有一个指针str保存了字符串的地址.返回一个临时对象的引用或指针,有可能会导致释放已经被释放掉的内存.这是一个潜在的风险.你第二个注释就是因为这个愿意是错的.
二第一个注释处 返回是int类型的引用.建议你改成这样:
int &ret(const int &i,const int &j)
{
    if(i>j)
        return i;
    else
        return j;
}

这样比较简洁,至于能不能返回int局部变量的引用,我就不知道了,还是等待别人的来回答吧.

学习切忌浮躁.
2008-9-17 19:25
zzt_428
Rank: 2
来自:南京师范大学
等级:注册会员
威望:1
帖子:156
积分:1740
注册:2008-7-6
&&

实验证明,可以返回一个局部内置类型变量的引用.

学习切忌浮躁.
2008-9-17 19:31
sunkaidong
Rank: 12Rank: 12Rank: 12
来自:南京师范大学
等级:版主
威望:4
帖子:4131
积分:44881
注册:2006-12-28

我用2005调试两个都是错的。。。
对于前者返回错误是

.\2.cpp(30) : warning C4172: returning address of local variable or temporary
.\2.cpp(36) : warning C4172: returning address of local variable or temporary
.\2.cpp(42) : warning C4172: returning address of local variable or temporary

学习需要安静。。海盗要重新来过。。
2008-9-17 21:30
zzt_428
Rank: 2
来自:南京师范大学
等级:注册会员
威望:1
帖子:156
积分:1740
注册:2008-7-6
回复

原来同样也不可以返回临时变量的引用.
但是VC6.0下似乎可以通过..VC6.0并不遵循标准的C++

学习切忌浮躁.
2008-9-18 00:32
关于我们 | 广告合作 | 编程中国 | 清除Cookies | Archiver | WAP | TOP

编程中国 版权所有,并保留所有权利。鲁ICP备08000592号
Powered by Discuz, Processed in 0.051261 second(s), 9 queries.
Copyright©2004-2008, BCCN.NET, All Rights Reserved