我读完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构造函数不会做任何特殊的事情,请不要定义它,然后让编译器生成一个。