在处理这个问题时,我发现了一种不一致的行为。
为什么引用绑定在构造函数中的行为与普通函数不同?
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 扩展。我得到了同样的结果。