在面向对象编程中,一个常见的任务是在派生类的构造函数中初始化基类的成员变量。但是,某些情况可能会阻止此初始化。让我们探讨一个这样的场景和推荐的解决方案。
考虑以下代码片段:
class A { public: int a, b; }; class B : public A { B() : A(), a(0), b(0) { } };
这里,程序尝试初始化基类 A 的成员变量 a 和 b派生类 B 的构造函数。但是,这种方法会失败并出现编译错误。
这个错误的原因在于 a 和 b 不是成员B 的成员,它们是基类 A 的成员。因此,只有 A 的构造函数才有权初始化它们。
与其直接在派生类构造函数中初始化 a 和 b,更有效的解决方案是将它们声明为基类中的受保护成员,并利用基类中的构造函数进行初始化。这种方法允许派生类通过继承来访问和初始化这些变量。
这是一个修改后的代码片段,演示了这种改进的方法:
class A { protected: A(int a, int b) : a(a), b(b) {} // Accessible to derived classes // Change "protected" to "public" to allow others to instantiate A. private: int a, b; // Keep these variables private in A }; class B : public A { public: B() : A(0, 0) // Calls A's constructor, initializing a and b in A to 0. { } };
在此修改后的代码中,基类的构造函数类 A 采用两个整数参数并相应地初始化成员变量 a 和 b。派生类 B 继承 A 的 protected 构造函数,并在自己的构造函数中调用它,以默认值 0 初始化 a 和 b。
这种方法确保成员变量的正确初始化,同时保持封装性并遵守面向对象编程原理。
以上是如何从派生类构造函数正确初始化基类成员变量?的详细内容。更多信息请关注PHP中文网其他相关文章!