Maison >développement back-end >C++ >Explication détaillée de l'héritage des fonctions C++ : quelle est l'essence du polymorphisme ?
Présentation de l'héritage de fonctions : l'héritage de fonctions en C++ est implémenté via le mot-clé override, permettant aux sous-classes de remplacer les fonctions de la classe parent, rendant ainsi possible le polymorphisme, c'est-à-dire que les objets affichent des comportements différents au moment de l'exécution, même s'ils appartiennent à la même classe parent.
Dans la programmation orientée objet, l'héritage est un mécanisme important, qui permet aux sous-classes d'hériter des données membres et des fonctions membres des classes parentes. L'héritage de fonction fait référence à l'héritage des fonctions membres de la classe parent à la classe enfant.
Le polymorphisme est un concept clé de la programmation orientée objet qui permet aux objets de se comporter différemment au moment de l'exécution, même s'ils appartiennent à la même classe parent. L'héritage de fonctions est un moyen d'atteindre le polymorphisme.
En C++, l'héritage de fonctions est implémenté via le mot-clé override
. Lorsqu'une sous-classe définit une fonction avec le même nom et la même signature que la classe parent, la fonction est marquée override
. Cela indique au compilateur que la sous-classe remplace les fonctions de la classe parent. override
关键字实现。当子类定义了一个与父类同名且具有相同签名的函数时,该函数被标记为 override
。这会告诉编译器,子类正在覆盖父类的函数。
class Base { public: virtual void print() { std::cout << "Base class" << std::endl; } }; class Derived : public Base { public: virtual void print() override { std::cout << "Derived class" << std::endl; } };
在此示例中,Base
类定义了一个 print()
函数,而 Derived
类通过 override
关键字覆盖了该函数。因此,当调用 Derived
类对象的 print()
函数时,它将打印 "Derived class",而不是 "Base class"。
override
函数必须是虚函数。虚函数通过 virtual
关键字声明,它允许子类覆盖父类的函数。在上面的示例中,print()
函数是虚函数。
下面是一个演示函数继承和多态的代码案例:
#include <iostream> class Shape { public: virtual double getArea() = 0; }; class Rectangle : public Shape { public: double width, height; Rectangle(double w, double h) : width(w), height(h) {} double getArea() override { return width * height; } }; class Circle : public Shape { public: double radius; Circle(double r) : radius(r) {} double getArea() override { return 3.14 * radius * radius; } }; int main() { Shape* shapes[] = {new Rectangle(2, 3), new Circle(4)}; for (int i = 0; i < 2; i++) { std::cout << "Area of " << (i == 0 ? "Rectangle" : "Circle") << ": " << shapes[i]->getArea() << std::endl; } return 0; }
在该案例中,Shape
是形状类的基类,它定义了一个纯虚函数 getArea()
。Rectangle
和 Circle
类从 Shape
类继承,并覆盖了 getArea()
函数以计算各自的面积。
在 main()
函数中,使用多态,一个基类数组被用于存储 Rectangle
和 Circle
对象。由于 getArea()
rrreee
Base
définit une fonction print()
, et la classe Derived
passe override
Le mot-clé remplace cette fonction. Par conséquent, lorsque la fonction print()
d'un objet de classe Derived
est appelée, elle affichera "Classe dérivée" au lieu de "Classe de base". Fonction virtuelle🎜🎜override
La fonction doit être une fonction virtuelle. Les fonctions virtuelles sont déclarées avec le mot-clé virtual
, qui permet aux sous-classes de remplacer les fonctions de la classe parent. Dans l'exemple ci-dessus, la fonction print()
est virtuelle. 🎜🎜Cas pratique🎜🎜Ce qui suit est un exemple de code qui démontre l'héritage et le polymorphisme des fonctions : 🎜rrreee🎜Dans ce cas, Shape
est la classe de base de la classe shape, qui définit une fonction virtuelle puregetArea(). Les classes Rectangle
et Circle
héritent de la classe Shape
et remplacent la fonction getArea()
pour calculer leurs aires respectives. . 🎜🎜Dans la fonction main()
, en utilisant le polymorphisme, un tableau de classes de base est utilisé pour stocker les objets Rectangle
et Circle
. Puisque la fonction getArea()
est remplacée, la zone correcte est imprimée en fonction du type d'objet. 🎜🎜Avec l'héritage de fonctions et le polymorphisme, nous pouvons construire des programmes flexibles et extensibles avec différents comportements. 🎜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!