从类型的右值初始化类型为'std :: vector <double>&'的非const引用

Bha*_*kar 3 c++

我正在学习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)

因为它调用未定义的行为.(请注意,这与您的示例不同,因为您返回的函数的参数当然是活的,但值得注意这种情况,因为这是一个常见的错误.)