9

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

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

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
}

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

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

4

1 回答 1

16
A a(B());

是一个名为 a 的函数的声明,它返回一个 A,并采用一个指向函数的指针,而没有返回 B 的参数。请参见 此处。添加括号,你会得到你期望的错误:

A a((B()));
于 2009-08-21T08:44:19.003 回答