const引用绑定到右值

fni*_*eto 9 c++ c++11

在处理这个问题时,我发现了一种不一致的行为.

为什么引用绑定在构造函数中与常用函数的行为不同?

struct A {
};

struct B : public A {
  B(){}
private:
  B(const B&);
};

void f( const B& b ) {}

int main() {
  A a( B() ); // works
  A const & a2 = B(); // C++0x: works, C++03: fails
  f( B() );  // C++0x: works, C++03: fails
}
Run Code Online (Sandbox Code Playgroud)

我已经使用g ++ - 4.1和Comeau 4.2.45.2在严格的C++ 03模式下测试了C++ 03并且禁用了C++ 0x扩展.我得到了相同的结果.

对于C++ 0x,在宽松模式下使用g ++ - 4.4和Comeau 4.3.9进行了测试,并启用了C++ 0x扩展.我得到了相同的结果.

APr*_*mer 16

A a(B());
Run Code Online (Sandbox Code Playgroud)

是一个名为a返回A的函数的声明,并且在没有参数返回B的情况下获取指向函数的指针.请参见 此处.添加括号,您将得到预期的错误:

A a((B()));
Run Code Online (Sandbox Code Playgroud)

  • 众所周知的"最令人烦恼的解析". (7认同)