在处理这个问题时,我发现了一种不一致的行为.
为什么引用绑定在构造函数中与常用函数的行为不同?
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)
| 归档时间: |
|
| 查看次数: |
38846 次 |
| 最近记录: |