关于右值引用的一个错误。

来源:互联网 发布:淘宝客服骂人投诉电话 编辑:程序博客网 时间:2024/05/22 17:36


实验课上,有同学遇到类似如下代码的错误。

1. 如下代码编译时会出错。
#include <string>
using namespace std;
class Complex{
public:
    Complex(float r = 0, float i = 0){
       re = r;
       im = i;
    }
    void print(){
       cout<<re<<"+"<<im<<endl;
    };
private:
    float re, im;
};
void f1(Complex &c){
   c.print();
}
Complex f2(){
   Complex c(1, 2);
   return c;
}
int main(){
   f1(f2);
   return 0;
}

编译结果(MinGW):
||=== Build: Debug in test (compiler: GNU GCC Compiler) ===|
E:\CPPTest\test\main.cpp||In function 'int main()':|
E:\CPPTest\test\main.cpp|25|error: invalid initialization of non-const reference of type 'Complex&' from an rvalue of type 'Complex (*)()'|
E:\CPPTest\test\main.cpp|17|error: in passing argument 1 of 'void f1(Complex&)'|
||=== Build failed: 2 error(s), 0 warning(s) (0 minute(s), 0 second(s)) ===|

2. 出现的错误与右值引用有关系,可以百度“右值引用”,可找到答案。
简单讲,由于临时变量在被赋予新值之前,都会被销毁,此规则可防止修改临时变量的值。
代码改为如下后,编译通过。
#include <iostream>
#include <iomanip>
#include <string>
using namespace std;
class Complex{
public:
    Complex(float r = 0, float i = 0){
       re = r;
       im = i;
    }
    void print() const{                                 //改为常函数
       cout<<re<<"+"<<im<<endl;
    };
private:
    float re, im;
};
void f1(const Complex &c){                   //改为常引用
   c.print();
}
Complex f2(){
   Complex c(1, 2);
   return c;
}
int main(){
   f1(f2());
   return 0;
}

0 0