如何实现菱形继承的移动构造函数?

piw*_*iwi 6 c++ inheritance c++11

我有一个菱形的类层次结构,其中没有默认构造函数,也没有复制构造函数.我有两个构造函数是一个"移动",另一个是对对象的左值引用:

struct base {
    base(base&&) = default;
    base(member_type&& m): member_(std::move(m)) {}
    member_type member_;
};

struct virt_1: virtual base {
    virt_1(virt_1&& rhs): base(std::move(rhs)) {}
    virt_1(member_type&& m): base(std::move(m)) {}
};

struct virt_2: virtual base {
    virt_2(virt_2&& rhs): base(std::move(rhs)) {}
    virt_2(member_type&& m): base(std::move(m)) {}
};

struct concrete: virt_1, virt_2 {
    concrete(concrete&& rhs) // ???
};
Run Code Online (Sandbox Code Playgroud)

除了不使用菱形层次结构外,是否可以为具体类实现移动构造函数?

谢谢!

Jon*_*ely 9

要求编译器提供实现有什么问题?

concrete(concrete&&) = default;
Run Code Online (Sandbox Code Playgroud)

我将构造virt_1virt_2移动构造函数定义为默认.

如果你真的想要,你可以写出来:

concrete(concrete&& rhs)
: base(std::move(rhs)), virt_1(std::move(rhs)), virt_2(std::move(rhs))
{ }
Run Code Online (Sandbox Code Playgroud)

或者如果你真的喜欢打字:

    concrete(concrete&& rhs)
    : base(static_cast<base&&>(rhs)),
      virt_1(static_cast<virt_1&&>(rhs)),
      virt_2(static_cast<virt_2&&>(rhs))
    { }
Run Code Online (Sandbox Code Playgroud)

virt_1和base 的初始化器virt_2是无用的,因为它们只调用base构造函数,因为它是一个虚拟基础,它们在concrete调用它时不会这样做,但由于你选择了构造函数,你不能默认构造它们并且是必需的用rvalue初始化它们,即使它们对它没有任何作用.