Présentation
EnglishRÉSUMÉ
Cet article présente trois exemples de programmes utilisant les fonctionnalités du langage orienté objet C++. Le premier exemple illustre l'utilisation des classes, à travers la manipulation d'ensembles d'entiers. Le second exemple traite des patrons de classe. Et le troisième concerne la création d'une classe permettant de gérer une liste chaînée d’objets de types différents.
Lire cet article issu d'une ressource documentaire complète, actualisée et validée par des comités scientifiques.
Lire l’articleAuteur(s)
-
Claude DELANNOY : Ingénieur de l’ENSEM (École nationale supérieure d’électricité - et de mécanique) de Nancy - Ingénieur informaticien au CNRS (Centre national de la recherche scientifique)
INTRODUCTION
Nous proposons quelques exemples de programmes illustrant la plupart des fonctionnalités de C++ que nous venons de présenter dans l’article [S 8 065].
DOI (Digital Object Identifier)
Cet article fait partie de l’offre
Automatique et ingénierie système
(139 articles en ce moment)
Cette offre vous donne accès à :
Une base complète d’articles
Actualisée et enrichie d’articles validés par nos comités scientifiques
Des services
Un ensemble d'outils exclusifs en complément des ressources
Un Parcours Pratique
Opérationnel et didactique, pour garantir l'acquisition des compétences transverses
Doc & Quiz
Des articles interactifs avec des quiz, pour une lecture constructive
Présentation
3. Exemple 3 : liste hétérogène
Nous allons créer une classe permettant de gérer une liste chaînée d’objets de types différents et disposant des fonctionnalités suivantes :
-
ajout d’un nouvel élément ;
-
affichage des valeurs de tous les éléments de la liste ;
-
mécanisme de parcours de la liste.
Rappelons que, dans une liste chaînée, chaque élément comporte un pointeur sur l’élément suivant. En outre, un pointeur désigne le premier élément de la liste. Cela correspond à ce schéma :
Mais ici l’on souhaite que les différentes informations puissent être de types différents. Aussi chercherons nous à isoler dans une classe (nommée liste) toutes les fonctionnalités de gestion de la liste elle-même sans entrer dans les détails spécifiques aux objets concernés. Nous appliquerons alors ce schéma :
La classe liste elle-même se contentera donc de gérer des éléments simples réduits chacun à :
-
un pointeur sur l'élément suivant ;
-
un pointeur sur l'information associée (en fait, ici, un objet).
On voit donc que la classe va posséder au moins :
-
un membre donnée : pointeur sur le premier élément (debut, dans notre schéma) ;
-
une fonction membre destinée à insérer dans la liste un objet dont on lui fournira l’adresse (nous choisirons l’insertion en début de liste, par souci de simplification).
L’affichage des éléments de la liste se fera en appelant une méthode affiche, spécifique à l’objet concerné. Cela implique la mise en oeuvre de la ligature dynamique par le biais des fonctions virtuelles. La fonction affiche sera définie dans un premier type d’objet (nommé ici mere) et redéfinie dans chacune de ses descendantes.
En définitive, on pourra gérer une liste d'objets de types différents sous réserve que les classes correspondantes soient toutes dérivées d'une même classe de base. Cela peut sembler quelque peu restrictif. En fait, cette « famille de classes » peut toujours être obtenue par la création d'une classe abstraite (réduite au minimum, éventuellement à une fonction affiche vide ou virtuelle pure) destinée simplement à donner naissance aux classes concernées. Bien entendu, cela n'est concevable...
Cet article fait partie de l’offre
Automatique et ingénierie système
(139 articles en ce moment)
Cette offre vous donne accès à :
Une base complète d’articles
Actualisée et enrichie d’articles validés par nos comités scientifiques
Des services
Un ensemble d'outils exclusifs en complément des ressources
Un Parcours Pratique
Opérationnel et didactique, pour garantir l'acquisition des compétences transverses
Doc & Quiz
Des articles interactifs avec des quiz, pour une lecture constructive
Exemple 3 : liste hétérogène
Cet article fait partie de l’offre
Automatique et ingénierie système
(139 articles en ce moment)
Cette offre vous donne accès à :
Une base complète d’articles
Actualisée et enrichie d’articles validés par nos comités scientifiques
Des services
Un ensemble d'outils exclusifs en complément des ressources
Un Parcours Pratique
Opérationnel et didactique, pour garantir l'acquisition des compétences transverses
Doc & Quiz
Des articles interactifs avec des quiz, pour une lecture constructive