实验课上,有同学遇到类似如下代码的错误。
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;
}