#include <iostream>
using namespace std;
class Student
{
private:
string _name;
public:
Student( const char * name) { _name = name; }
void print(){
cout<<this->_name<<endl;
}
};
int main()
{
Student& stu = Student("Randy"); //这句报错;
stu.print();
return 0;
}
错误提示信息如下:error: invalid initialization of non-const reference of type 'Student&' from an rvalue of type 'Student'
经过查找资料,得知Student("Randy")这句返回的是一个右值,而此时的引用是一个普通引用(左值引用),所以才出现了rvalue这样的错误的信息,经过查找资料,const引用可以允许任意表达式作为初始值,只要该表达式的结果能转化成引用的类型即可,详见C++ primer P55。于是我把出错的那句修改为:
const Student& stu = Student("Randy");
并且const引用可以把一个引用绑定到和引用的类型不同的对象上,此时可能会导致数据的丢失,类似于double向int转化的那种丢失。但是丢失归丢失,语法确实是允许的;
但是还是出错,错误提示信息如下:error: passing 'const Student' as 'this' argument of 'void Student::print()'discards qualifiers [-fpermissive]
接着查资料,发现C++11新加了“右值引用”这个类型,具体即用&&代表右值引用,而不是&。右值引用的介绍在C++ Primer P471,接着把出错语句修改为:
Student&& stu = Student("Randy");
成功运行! (我想第一种方式之所以不行,估计是因为第一种方式隐含的存在修饰数据的风险,所以编译器才不允许第一种方式的做法;出错信息也提到了 'void Student::print()' 的’this‘参数有discard qualifiers的风险。)
结果: