为什么它可以在 MS Visual C++ 上编译?
struct myClass{};
void func(myClass& arg){}
void main() {
func( myClass() ); // works even though func only takes myClass&
} // (not const myClass&!!)
这是否也适用于其他编译器,或者是 MSVC 特定的(甚至是编译器错误?)。我什至可以像这样获得这个右值的引用:
void func(myClass* arg){}
int main() {
func( &myClass() );
}
这仅适用于使用构造函数临时创建的对象。这不适用于任何其他右值,例如 (myClass() + myClass()) 。
它可以编译,因为 MSVC 有一个不符合标准的“扩展”,允许将非常量引用绑定到临时对象。
第一个示例不应在符合标准的编译器上进行编译。
在第二个示例中,您使用临时地址来设置指针的值。这也应该会导致错误。
Clang 3.2 产生:
错误:获取类型为“Foo”的临时对象的地址[-Waddress-of-temporary]
而 GCC 4.7.3 产生
错误:获取临时地址 [-fpermissive]
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)