C++ 显式默认移动构造函数
根据c++11标准,只有在以下情况下才会生成默认移动构造函数:C++ 显式默认移动构造函数,c++,constructor,c++11,clang,default-constructor,C++,Constructor,C++11,Clang,Default Constructor,根据c++11标准,只有在以下情况下才会生成默认移动构造函数: X没有用户声明的复制构造函数,并且 X没有用户声明的复制分配运算符 X没有用户声明的移动分配运算符 X没有用户声明的析构函数,并且 移动构造函数不会隐式定义为已删除 我仍然可以显式地默认它吗?似乎在叮当声中正常工作。例如: class MyClass { private: std::vector<int> ints; public: MyClass(MyClass const& other) : in
- X没有用户声明的复制构造函数,并且
- X没有用户声明的复制分配运算符
- X没有用户声明的移动分配运算符
- X没有用户声明的析构函数,并且
- 移动构造函数不会隐式定义为已删除
class MyClass {
private:
std::vector<int> ints;
public:
MyClass(MyClass const& other) : ints(other.ints) {}
MyClass(MyClass&& other) = default;
};
class-MyClass{
私人:
std::向量整数;
公众:
MyClass(MyClass常量和其他):ints(other.ints){}
MyClass(MyClass&&other)=默认值;
};
该规则的动机是,如果默认的复制构造函数不适用于您的类,那么默认的移动构造函数也可能不起作用(第5条规则,或者我们在C++11中使用的任何规则)。所以,是的,你可以显式地默认它,以你作为程序员的荣誉,它会工作
在示例代码中,您可以删除复制构造函数,因为它与默认构造函数的作用相同。是的,对于可以使用
=default
自动生成的函数,您始终可以显式调用默认生成。这就是语法的作用