0

我知道对于独立类,您应该避免在复制构造函数中调用赋值运算符。复制和交换以及将重用的代码移动到私有成员函数是轻松重用代码的两种方法。但是,最近我遇到了一个问题。这是代码:

// Derived.h
class Derived : Base {
  // bunch of fun stuff here
  // ...
  // constructor that builds a derived object from a base one
  explicit Derived(const Base& base);
  // Assignment operator for moving base class member variables into the derived one
  Derived& operator=(const Base& base);
};
// Derived.cpp
Derived::Derived(const& Base base) {
  *this = base; // use assignment operator from derived to base
}
Derived& Derived::operator=(const Base& base) {
  static_cast<Base>(*this) = base;  // call base class assignment operator
}

在这个给定的应用程序中,这一切实际上都是有意义的,因为派生类现在可以对它刚刚从基类接收到的成员执行操作,以填充对象的其余部分。此外,这为用户提供了一种将基础对象转换为派生对象的安全方式。我似乎缺少的是这样的代码是否是好的代码实践,或者是否有更简单/更好的方法来完成我想要做的事情?正如我之前提到的,我知道从独立类中的复制构造函数调用赋值运算符通常是不可行的,但是从另一个构造函数调用赋值运算符呢?

4

2 回答 2

8
Derived::Derived(const Base& base) {
  *this = base;
}

此默认构造Base对象内的子Derived对象,然后分配它。你可能会做得更好:

Derived::Derived(const Base& base)
  : Base(base)
{
}

它使用Base.

于 2013-06-26T00:58:14.937 回答
1

在构造函数中,您应该使用初始化列表:

Derived::Derived(const Base& base) : Base(base) {}

如果你真的想在某个地方重新分配你的基本切片,你只需要显式调用已经存在的 op= :

*this = Base::operator=(base);
于 2013-06-26T01:01:29.653 回答