我知道在c++03中,非const引用无法绑定到rvalue。
T& t = getT();
是无效的,在c++11中,我们可以这样做:T&& t = getT();
但是上面的代码呢?在c++11中能用吗?
我使用vs11测试了下面的代码:
Foo getFoo() {
return Foo();
}
void fz(Foo& f) {
}
int getInt() {
return int();
}
void iz(int& i) {
}
int main() {
{
Foo& z = getFoo(); //ok
fz(getFoo()); //ok
int& z2 = getInt(); //error: initial value of reference to non-const must be an lvalue
iz(getInt()); //same as above
}
}
Foo
是一个自定义类,我不理解前两行为什么编译通过。被z
引用的临时对象在main函数内部作用域结束时会被销毁。标准对此有规定吗?
class Foo {
public:
Foo() {
std::cout << "constructed\n";
}
~Foo() {
std::cout << "destructed\n";
}
};
我刚刚看到了一个类似的问题:VS2010的一个bug?允许将非const引用绑定到rvalue,甚至没有警告?