处理this问题,我发现行为不一致。
为什么引用绑定在构造函数中与常用函数的行为不同?
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扩展。我得到了同样的结果。
答案 0 :(得分:16)