默认的构造函数好奇心
Default constructor curiosity
而
MyClass m();
是经典的陷阱,因为它没有声明变量M,而是以零参数并返回myclass的功能。但是,我发现在Visual Studio中,以下语句会产生相同的问题(似乎以某种方式与上述语句相提并论):
MyClass m( MyClass() );
任何人都可以解释这种行为吗?
注意:预期的内容更"明确"版本正确(即称为默认值,然后是移动构造函数)。
MyClass m( std::move( MyClass() ) );
它是最烦人的解析问题。
MyClass m( MyClass() );
该行被解析,就像一个名为 m 返回的对象 myclass 的函数,并接受单个参数,该参数是一个无参数和返回值的函数指针类型 myclass 。
在这里:
MyClass m( std::move( MyClass() ) );
std ::移动帮助编译器按预期解析行。
是的,这是经典的最烦人的解析。看起来像功能的所有内容都是函数,即使它可能是其他功能。
有几种遗留方法将其转化为适当的变量定义,但最好的方法是使用统一的初始化:
MyClass m{MyClass()};
(尽管上述示例是多余的事实,一个更好的例子是当类型不同时,例如A m{B()};
)
相关文章:
- "error: no matching function for call to"构造函数错误
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 如果C++类在类方法中具有动态分配,但没有构造函数/析构函数或任何非静态成员,那么它仍然是POD类型吗
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 选择要调用的构造函数
- 如何委托派生类使用其父构造函数?
- 构造函数正在调用一个使用当前类类型的函数
- 没有用于初始化C++中的变量模板的匹配构造函数
- 初始化具有非默认构造函数的std::数组项的更好方法
- 当从函数参数中的临时值调用复制构造函数时
- 在c++构造函数中使用随机字符串生成器
- 一对向量构造函数:初始值设定项列表与显式构造
- 从构造函数抛出异常时如何克服内存泄漏
- 我不明白为什么我声明一个空的内部结构并将其传递给构造函数
- 继承:构造函数,初始化C++11中基类的类C数组成员
- 具有默认模板类型的默认构造函数的类型推导
- 使用dynamic_cast和构造函数时出错
- 在c++中使用向量时,如何调用构造函数和析构函数
- 默认的构造函数好奇心