base class 中的单个受保护成员变量 VS derived class 中的多个私有成员变量

Single protected member variable in base class VS Multiple private member variable in derived class

场景 1:基于 class

的单个受保护成员变量
class ImageFilter
{
 public:
  // common function
 protected:
  std::vector<uchar> m_image;
};

class MeanFilter : public ImageFilter
{
 public:
  // function that manipulates m_image
};

class MedianFilter : public ImageFilter
{
 public:
  // function that manipulates m_image
};

场景2:派生中有多个私有成员变量class

class ImageFilter
{
 public:
  // common function
};

class MeanFilter : public ImageFilter
{
 public:
  // function that manipulates m_image
 private:
  std::vector<uchar> m_image;
};

class MedianFilter : public ImageFilter
{
 public:
  // function that manipulates m_image
 private:
  std::vector<uchar> m_image;
};

哪个更好,为什么?

https://softwareengineering.stackexchange.com/questions/162643/why-is-clean-code-suggesting-avoiding-protected-variables 强烈建议不要使用受保护的变量,但 MeanFilter 显然 "is-a" ImageFilter 和 m_image 将需要用于各种图像过滤器,我想不出一种不使用protected继承成员变量的方法。

不同之处在于,通过在基础 class 中使用单个成员,您可以提供默认实现,甚至可以提供操作图像的基础 class 成员函数。

然而,不利的一面是您对派生的 class 可能是什么设置了限制,并且您强迫它们基于图像。例如,派生的 class 基于某些公式动态合成图像像素不适合此模式。另一个例子是一个过滤器,它不需要单个图像而是一个图像向量:它将被迫以不同的方式对待它们(例如,一个在基本成员中,另一个在向量中)。