在派生类中使用基类的私有成员变量的最佳方法

Best way to use a base class's private member variable in derived class

本文关键字:成员 变量 方法 最佳 基类 派生      更新时间:2023-10-16

我有以下代码,其中基类定义了一个纯虚函数,派生类定义这个纯虚函数以使用基类的私有成员变量var执行一些计算(但是var不会被更改(。var通常是一些大型结构。

从设计的角度来看,我读到在这种情况下,通常不赞成将var作为受保护的成员。实现我想要的最好方法是将var作为论据传递给virtual_func()吗?

这激发了第二个问题。如果我想修改virtual_func中的var怎么办?这会改变你的答案吗?

class base
{
public:
void search()
{
//virtual func in derived class must use var in base class, but not change var
virtual_func();
}
private:
T var;
virtual void virtual_func() = 0;
};
class derived : public base
{
void virtual_func()
{
//does something with base class's var, but not alter it
}
};

Bjarne Stroustrup在他的《C++的设计与演变》一书中讨论了第13.9节中的protected

它是为您的用例添加的:允许派生类访问基类成员,而无需向所有人公开这些成员,或滥用friend声明。 五年后,提出请求的人(项目(禁止使用受保护的成员变量,因为它们成为错误和复杂维护的来源。 他最后说,受保护的数据不是一个好主意,但受保护的成员功能很好。

遵循这些准则,您应该将所有基类数据保留private,并添加protectedgetter 和 setter 函数来访问数据。

根据您的用例以及复制数据的成本,您的 getter 可以返回数据的副本或对其的引用(或常量引用(。 返回非常量引用将允许您直接通过赋值 (getVar() = newvar;( 修改数据,或修改类的特定数据成员。 返回 const 引用并使用 setter 函数,可以在不过度公开类的情况下更多地封装数据。 setter 函数还允许您更好地控制对var的更改,包括执行可能需要的任何验证。

如果不想在基类中进行varprotected,可以在基类中添加一个publicprotectedgetter 函数,然后可以在派生类中调用该函数。 类似的东西

T getVar() const { return var; }

"从设计的角度来看,我读到,在这种情况下,通常不赞成将var作为受保护的成员。

从你阅读的任何地方似乎是一个错误的概念。如果您必须在class derived中访问base::var,那么最好的设计决策是将varprotected。其他一切都会干扰封装。除了您的问题中提到的要求之外,protected还有什么用例。:-)