Maison >développement back-end >C++ >Comment initialiser correctement les variables membres de la classe de base dans un constructeur de classe dérivée ?
Initialisation des variables membres de la classe de base dans le constructeur de classe dérivée
Lorsque vous travaillez avec l'héritage de classe, une question courante se pose : comment initialiser la classe de base variables membres dans un constructeur de classe dérivée. Une première tentative de le faire peut prêter à confusion, comme démontré ci-dessous :
class A { public: int a, b; }; class B : public A { B() : A(), a(0), b(0) { } };
Ce code ne parvient pas à se compiler, soulevant la question : pourquoi ne pouvons-nous pas initialiser a et b dans B ?
La raison réside dans le fait que a et b ne sont pas membres de B. Ils appartiennent à la classe de base A. Seul A peut initialiser ses propres variables membres.
Une solution possible est de faire a et b membres publics de A, permettant à B d'attribuer des valeurs directement. Cependant, cela n'est pas recommandé car cela enfreint le principe d'encapsulation.
Au lieu de cela, une approche plus robuste consiste à définir un constructeur en A qui permet aux classes dérivées de spécifier des valeurs d'initialisation. Ceci peut être réalisé en rendant le constructeur protégé et accessible aux sous-classes :
class A { protected: A(int a, int b) : a(a), b(b) {} // Accessible to derived classes private: int a, b; // Keep variables private within A }; class B : public A { public: B() : A(0, 0) // Calls A's constructor, setting a and b to 0 within A { } };
Cette solution garantit que a et b sont correctement initialisés dans A, garantissant l'intégrité et l'encapsulation des données.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!