不要返回局部变量的引用或指针

不要返回局部变量的引用或指针,因为函数返回时,局部变量会被释放,引用或指针指向的内容会失效。

例如以下程序

#include <iostream>
using namespace std;
class A
{
public:
    A(int a)
    {
        _num = a;
        cout << "无参构造函数" << endl;
    }
    A(const A& a)
    {
        this->_num = a._num;
        cout << "拷贝构造函数" << endl;
    }
    A& operator = (const A& a)
    {
        this->_num = a._num;
        cout << "赋值运算符重载" << endl;
        return *this;
    }
    void print()
    {
        cout << this->_num << endl;
    }
    ~A()
    {
        cout << "析构函数" << endl;
    }
private:
    int _num;
};
 



  • 返回局部变量
A boo(const A a)
{
    cout << "A tmp = a" << endl;
    A tmp = a;//调用拷贝构造函数
    cout << "return tmp" << endl;
    return tmp;//外部会自动定义一个临时变量,以tmp初始化,所以调用拷贝构造函数
}

int main()
{
    cout << "A a" << endl;
    A a(1);//调用无参构造函数
    cout << "A b(a)" << endl;
    A b(a);//调用拷贝构造函数
    cout << "-----------------------------------------------" << endl;
    b= boo(a);//当把a值传递给形参时,会调用拷贝构造函数;返回时,会定义临时变量以函数内返回值初始化

    b.print();
    return 0;
}

运行结果为:

A a
无参构造函数
A b(a)
拷贝构造函数
-----------------------------------------------
拷贝构造函数 //实参初始化形参,调用拷贝构造函数
A tmp = a
拷贝构造函数 
return tmp
拷贝构造函数 //局部变量tmp初始化内存中临时变量
析构函数 //析构局部变量tmp
析构函数 //析构局部变量a
赋值运算符重载 //临时变量赋值给b
析构函数  //析构临时变量
1
析构函数  //析构main中的b
析构函数  //析构main中的a


  • 返回临时变量的引用
 A& boo(const A a)
{
    cout << "A tmp = a" << endl;
    A tmp = a;//调用拷贝构造函数
    cout << "return tmp" << endl;
    return tmp;//外部会自动定义一个临时变量,以tmp初始化,所以调用拷贝构造函数
}

 int main()
 {
     cout << "A a" << endl;
     A a(1);//调用无参构造函数
     cout << "A b(a)" << endl;
     A b(a);//调用拷贝构造函数
     cout << "-----------------------------------------------" << endl;
     b = boo(a);//当把a值传递给形参时,会调用拷贝构造函数;返回时,会定义临时变量以函数内返回值初始化

     b.print();
     return 0;
 }

运行结果为:

A a
无参构造函数
A b(a)
拷贝构造函数
-----------------------------------------------
拷贝构造函数
A tmp = a
拷贝构造函数
return tmp  //返回引用时不需要初始化临时变量,只是一个别名
析构函数  //析构局部变量tmp
析构函数  //析构局部变量 a
赋值运算符重载 //tmp的引用赋值给b
-858993460 //由于tmp已经被析构,所以是错误值
析构函数 //析构b
析构函数 //析构a


总结

返回局部变量与返回局部变量的引用有所不同

  • 返回局部变量会先将返回值初始化一个临时变量,函数返回后,局部变量被释放,但临时变量还存在。根据需要访问或者不访问临时变量,在下一条语句,临时变量自动销毁。
  • 而返回引用时,该引用是局部变量的一个别名,不会有临时变量,随着函数返回后局部变量被析构,引用也失去意义。
  • 所以不要返回局部变量的引用

引用

  1. http://bbs.csdn.net/topics/390153974
  2. C++ Primer

推荐阅读更多精彩内容