注册 登录
编程论坛 C++教室

返回局部对象的引用,小弟遇到问题了!求助

独孤剑魔 发布于 2008-09-16 16:51, 1629 次点击
#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;
}
请各位高手讲讲我注释的第一行,为什么此引用没导致运行时出错。

[[it] 本帖最后由 独孤剑魔 于 2008-9-16 17:04 编辑 [/it]]
7 回复
#2
独孤剑魔2008-09-16 17:03
还是上面那个问题,string &ret(const string& s)函数明明需要返回一个string 对象,在main函数中,如果将
string gg = ret(aa)--改为ret(aa);运行时就不会出错,在java中我记得是不可以的,因为需要有相应的类型对象来接受return返回的对象,但是c++中,这样写编译与运行都不会出错了,求教高手把握第一问于第二问一起回答。谢谢了
问题整理:
问题1:请看1楼代码段,加注释地方。
问题2:2楼,上面的那些话,谢谢。
#3
独孤剑魔2008-09-16 22:47
为什么没人回答啊???
#4
dsj_22008-09-17 06:25
我来回答,这是因为C++中使用临时复制对象来传值的缘故.例如: int h=ret(i,j); 虽然返回值k是局部对象,但是return k;时C++会用一个临时复制对象来保存k的值,接着k的生存期结束,然后临时对象的值被赋给h,最后临时复制对象的生存期结束!
#5
zzt_4282008-09-17 19:25
浅见
我个人的观点是:
String 类内部有一个指针str保存了字符串的地址.返回一个临时对象的引用或指针,有可能会导致释放已经被释放掉的内存.这是一个潜在的风险.你第二个注释就是因为这个愿意是错的.
二第一个注释处 返回是int类型的引用.建议你改成这样:
int &ret(const int &i,const int &j)
{
    if(i>j)
        return i;
    else
        return j;
}

这样比较简洁,至于能不能返回int局部变量的引用,我就不知道了,还是等待别人的来回答吧.
#6
zzt_4282008-09-17 19:31
&&
实验证明,可以返回一个局部内置类型变量的引用.
#7
sunkaidong2008-09-17 21:30
我用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
#8
zzt_4282008-09-18 00:32
回复
原来同样也不可以返回临时变量的引用.
但是VC6.0下似乎可以通过..VC6.0并不遵循标准的C++
1