不要返回局部变量的引用或指针,因为函数返回时,局部变量会被释放,引用或指针指向的内容会失效。
例如以下程序
#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
总结
返回局部变量与返回局部变量的引用有所不同
- 返回局部变量会先将返回值初始化一个临时变量,函数返回后,局部变量被释放,但临时变量还存在。根据需要访问或者不访问临时变量,在下一条语句,临时变量自动销毁。
- 而返回引用时,该引用是局部变量的一个别名,不会有临时变量,随着函数返回后局部变量被析构,引用也失去意义。
- 所以不要返回局部变量的引用
引用
- http://bbs.csdn.net/topics/390153974
- C++ Primer