Primer C++ 第五版中文版 P201页提到了不要返回局部对象的引用或指针。
自己在学习vector容器的时候,希望建立一个vector容器存储的整数等差数列,开始写成这样:
vector<int> &vecSeries(int b, const int& dif, const int& n)
{
vector<int> intVec(n);
//向intVec中存入数字1~10
vector<int>::iterator it = intVec.begin();
vector<int>::iterator itE = intVec.end();
while (it!=itE)
{
*it = b;
b+=dif;
++it;
}
return intVec;
}
编译时说会返回局部变量或临时变量的地址。翻回前文了解了问题所在。临时变量在函数结束后可能被释放,不安全,返回其引用无意义,还有可能在之后修改该引用的内容时候更改掉其他关键的内存区,发生奇怪的错误。
去掉vecSeries前面的&,改成下面就好:
vector<int> vecSeries(int b, const int& dif, const int& n)
{
vector<int> intVec(n);
//向intVec中存入数字1~10
vector<int>::iterator it = intVec.begin();
vector<int>::iterator itE = intVec.end();
while (it!=itE)
{
*it = b;
b+=dif;
++it;
}
return intVec;
}
正如Primer C++中所说,要想确保返回值安全,我们不妨提问:引用所引用的是在函数之前已经存在的哪个对象?