为什么不允许获得对一个临时对象的非常量引用,哪个函数getx()
返回?显然,这是C ++标准所禁止的,但是我对这种限制的目的感兴趣,而不是对该标准的引用。
struct X
{
X& ref() { return *this; }
};
X getx() { return X();}
void g(X & x) {}
int f()
{
const X& x = getx(); // OK
X& x = getx(); // error
X& x = getx().ref(); // OK
g(getx()); //error
g(getx().ref()); //OK
return 0;
}
- 显然,对象的生存期不可能是原因,因为C ++ Standard 不禁止对对象的常量引用。
- 显然,上面的示例中的临时对象不是常量,因为允许调用非常量函数。例如,
ref()
可以修改临时对象。 - 另外,
ref()
允许您欺骗编译器并获得指向该临时对象的链接,从而解决了我们的问题。
此外:
他们说“将临时对象分配给const引用可延长该对象的寿命”,“关于非const引用却一无所获”。我还有一个问题。以下分配是否会延长临时对象的寿命?
X& x = getx().ref(); // OK