我读完Thomas Becker's "C++ Rvalue References"。我对Rvalues和Rvalue引用有几个问题。

假设我有一个简单的数组类:

template <class T>
MyArray
{
    ...
    T* m_ptr;  // Pointer to elements
    size_t m_count; // Count of elements
};

进一步假设它提供:
#if(__cplusplus >= 201103L)
MyArray(MyArray&& t)
  : m_ptr(std::move(t.m_ptr)), m_count(std::move(t.m_count))
{
    t.m_ptr = NULL;
    t.m_count = 0;
}
MyArray operator=(MyArray&& t)
{
    std::swap(*this, t);
    return *this;
}
#endif

现在,假设我有一个不添加新数据成员的派生类:
MyImprovedArray : public MyArray
{
    ...
};
MyImprovedArray需要什么?

是否还需要MyImprovedArray(MyImprovedArray&&)MyImprovedArray& operator=(MyImprovedArray&&)?如果是这样,是否仅需要执行基类std::move?还是也需要执行std::swap
MyImprovedArray(MyImprovedArray&& t)
    : MyArray(t)
{
}

最佳答案

Rule of five(或零)适用于派生类,而不管基类定义什么。

如果派生的MyImprovedArray的move构造函数不会做任何特殊的事情,请不要定义它,然后让编译器生成一个。

09-08 09:27