我正在学习c ++并尝试一些东西.编译器没有在注释2行引发错误.
int main(){
vector<double> a1;
a1.push_back(3);
a1.push_back(7);
a1.push_back(2);
vector<double>& a2 = a1; //COMMENT 1: This line has no error
vector<double>& a4 = print(a2); //COMMENT 2: Why this line has error? R value is an object then it should be referenced by a4?
return 0;
}
vector<double> print(vector<double>& a3){
cout<<"In print function the size of vector is :";
cout<<a3.size()<<endl;
return a3;
}
Run Code Online (Sandbox Code Playgroud)
小智 9
Blehh,所以......是的,返回值是暂时的.因此,持有对它的引用是没有意义的(想象一下:当临时被破坏时引用什么都没有引用).因此,它是不允许的.
您可以通过多种方式解决此问题:
I.持有const引用,如
const vector<double> &retVal = print();
Run Code Online (Sandbox Code Playgroud)
const引用将绑定临时的生命周期延长到引用的生命周期.
II.只需按值返回:
vector<double> retVal = print();
Run Code Online (Sandbox Code Playgroud)
III.返回对您知道将具有足够生命周期的对象的引用,例如类成员:
class Foo {
vector<double> vec;
public:
vector<double> &print() {
return vec;
}
};
Foo f;
vector<double> &retVal = f.print();
Run Code Online (Sandbox Code Playgroud)
但是,请不要从函数中返回对临时的引用,如下所示:
// this is wrong:
vector<double> &print()
{
vector<double> v;
return v;
}
Run Code Online (Sandbox Code Playgroud)
因为它调用未定义的行为.(请注意,这与您的示例不同,因为您返回的函数的参数当然是活的,但值得注意这种情况,因为这是一个常见的错误.)