Introduction à C++ pour programmeurs C



Documents pareils
Prénom : Matricule : Sigle et titre du cours Groupe Trimestre INF1101 Algorithmes et structures de données Tous H2004. Loc Jeudi 29/4/2004

Une introduction à Java

Licence Bio Informatique Année Premiers pas. Exercice 1 Hello World parce qu il faut bien commencer par quelque chose...

Cours de C++ François Laroussinie. 2 novembre Dept. d Informatique, ENS de Cachan

Programmer en JAVA. par Tama

LMI 2. Programmation Orientée Objet POO - Cours 9. Said Jabbour. jabbour@cril.univ-artois.fr

Pour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère

as Architecture des Systèmes d Information

Java Licence Professionnelle Cours 7 : Classes et méthodes abstraites

Génie Logiciel I. Cours VI - Typage statique / dynamique, fonctions virtuelles et classes abstraites, flots d entrées / sorties, et string

TP1 : Initiation à Java et Eclipse

Cours 1: Java et les objets

TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile

Héritage presque multiple en Java (1/2)

Chapitre V. Les classes : Object, Vector, etc.

INFO-F-105 Language de programmation I Séance VI

Programmation avec des objets : Cours 7. Menu du jour

Package Java.util Classe générique

Généralités sur le Langage Java et éléments syntaxiques.

Encapsulation. L'encapsulation consiste à rendre les membres d'un objet plus ou moins visibles pour les autres objets.

Facultés Universitaires Notre-Dame de la Paix. Conception et Programmation Orientées- Object

TD/TP PAC - Programmation n 3

Polymorphisme, la classe Object, les package et la visibilité en Java... 1

Langage et Concepts de Programmation Objet. 1 Attributs et Méthodes d instance ou de classe. Travaux Dirigés no2

RAPPELS SUR LES METHODES HERITEES DE LA CLASSE RACINE Object ET LEUR SPECIALISATION (i.e. REDEFINITION)

C++ COURS N 2 : CLASSES, DONNÉES ET FONCTIONS MEMBRES Classes et objets en C++ Membres d'une classe Spécification d'une classe Codage du comportement

4. Groupement d objets

Génie Logiciel avec Ada. 4 février 2013

Langage et Concepts de ProgrammationOrientée-Objet 1 / 40

Cours intensif Java. 1er cours: de C à Java. Enrica DUCHI LIAFA, Paris 7. Septembre Enrica.Duchi@liafa.jussieu.fr

Chapitre VI- La validation de la composition.

Introduction à C++ et à wxwidgets

P r ob lé m a t iq u e d e la g é n é r icit é. Pr in cip e d e la g é n é r icit é e n Ja v a ( 1 /3 )

Java Licence Professionnelle CISII, Cours 2 : Classes et Objets

et Programmation Objet

Bases Java - Eclipse / Netbeans

Apprendre la Programmation Orientée Objet avec le langage Java (avec exercices pratiques et corrigés)

Initiation à JAVA et à la programmation objet.

Classes et Objets en Ocaml.

Classe Interne, Anonyme & Enumération

Programmation Par Objets

Langage Java. Classe de première SI

Programmation Orientée Objet

Auto-évaluation Programmation en Java

Cette application développée en C# va récupérer un certain nombre d informations en ligne fournies par la ville de Paris :

Objets et Programmation. origine des langages orientés-objet

Exceptions. 1 Entrées/sorties. Objectif. Manipuler les exceptions ;

2. Comprendre les définitions de classes

Programmation par les Objets en Java

COMPARAISONDESLANGAGESC, C++, JAVA ET

Structure d un programme et Compilation Notions de classe et d objet Syntaxe

Premiers Pas en Programmation Objet : les Classes et les Objets

Utiliser Java sans BlueJ

Conventions d écriture et outils de mise au point

TD/TP PAC - Programmation n 3

Corrigés des premiers exercices sur les classes

30.avr.10 Présentation miniprojet. 9.mars.10 Cours 3 4.mai.10 Cours C mars.10 Cours 4 11.mai.10 Cours C++ 2

Traduction des Langages : Le Compilateur Micro Java

INITIATION AU LANGAGE JAVA

Introduction à Java. Matthieu Herrb CNRS-LAAS. Mars

PROGRAMMATION PAR OBJETS

Java 1.5 : principales nouveautés

Java c est quoi? Java pourquoi?

Programmation Orientée Objet application au langage Java Version Novembre 2007

Machines virtuelles fonctionnelles (suite) Compilation ML Java

Utilisation d objets : String et ArrayList

Classe ClInfoCGI. Fonctions membres principales. Gestion des erreurs

TP, première séquence d exercices.

Programmation Orientée Objet Java

Programmation MacOSX / ios

Tp 1 correction. Structures de données (IF2)

Types d applications pour la persistance. Outils de développement. Base de données préexistante? 3 modèles. Variantes avec passerelles

Cours de Programmation 2

Apprendre Java en 154 minutes

Diagramme de classes

TD3: tableaux avancées, première classe et chaînes

Informatique III: Programmation en C++

Généricité. en Java. (polymorphisme paramétrique) Philippe GENOUD UJF Janvier

INTRODUCTION A JAVA. Fichier en langage machine Exécutable

Présentation. Au programme. Fonctionnement. A l issue de ce module vous devriez...

Développement Logiciel

INITIATION AU LANGAGE C SUR PIC DE MICROSHIP

C++ Programmer. en langage. 8 e édition. Avec une intro aux design patterns et une annexe sur la norme C++11. Claude Delannoy

1/24. I passer d un problème exprimé en français à la réalisation d un. I expressions arithmétiques. I structures de contrôle (tests, boucles)

Programmation Orientée Objet

1 Définition d une classe en Java

JAVA TD0. Prise en main du langage Environnement de base JAVA 1

Avertissement : Ce cours suppose la connaissance et la maîtrise du langage C CONTENU DU COURS BIBLIOGRAPHIE

Anne Tasso. Java. Le livre de. premier langage. 10 e édition. Avec 109 exercices corrigés. Groupe Eyrolles, , ISBN :

Centre CPGE TSI - Safi 2010/2011. Algorithmique et programmation :

Plan Pédagogique du cours

Exercices sur les interfaces

Brefs rappels sur la pile et le tas (Stack. / Heap) et les pointeurs

Remote Method Invocation Les classes implémentant Serializable

Cours d initiation à la programmation en C++ Johann Cuenin

Programmation en C/C++

Java Licence Professionnelle CISII,

Généralités. javadoc. Format des commentaires. Format des commentaires. Caractères spéciaux. Insérer du code

Projet de programmation (IK3) : TP n 1 Correction

Chapitre 2. Classes et objets

Transcription:

SITEL - Université de Neuchâtel Introduction à C++ pour programmeurs C Dr. E. Benoist Novembre 2007 1

Table of Contents Héritage Surcharge de méthode Surcharge d opérateur Métodes virtuelles Destructeur Classe abstraite Exemple: Gestion des salles de l Université Librairie Standard Templates Strings Conteneurs / Iterateurs 2

Héritage et Polymorphisme Jour 1 : Notion d encapsulation Objet = structure contenant des membres variables et fonctions. Classe = groupe d objets; La classe possède des variables partagées par tous les objets ainsi que des méthodes ne nécessitant pas d instance. Jour 2 (matin): Héritage Héritage: une classe B étand une classe A Réutilisation de code Jour 2 (après midi): Librarie standard C++ Strings Conteneurs (Vecteurs, listes, map, iterateurs) 3

Héritage Une classe peut hériter d une ou plusieurs autres classes On dit dans ce cas qu elle étend ces classes. Principe la classe B hérite de la classe A Toute instance de B est automatiquement une instance de A Une instance de B a donc toutes les variables membres et les fonctions membres de A. Dans les méthodes de B on ne peut par contre voir que ce qui est protected et public de A. Héritage signifie : EST UN Un objet de la classe B est aussi un objet de la classe A (la réciproque n est pas vraie!!!) Héritage 4

Une classe B hérite d une classe A class B : public A {... ; Usage: int main() { B b; A a = b; A ptra = &b; // OK B ptrb = &a; // Erreur Héritage 5

Exemple avec Pointeurs A c1 = new A(); B c2 = new B(); B c3 = new B(); A c4 = c3; A c5 = new B(); Type vs Classe Les variables c4 et c5 sont de type ClassA, mais pointent sur des instances de la classe B Héritage 6

Héritage La classe mère (ClassA) class ClassA { public: ClassA(int v1, int v2); int getval1() const; int getval2() const; private: int val1 ; int val2; ; Héritage 7

Héritage des membres (Cont.) Définition de la classe fille (ClassB) class ClassB : public ClassA { public: ClassB(int v1, int v2, int v3); int getval3() const; void setval3(int v2); private: int val3 ; ; Héritage 8

Héritage des membres (Cont.) Dans la classe B on peut utiliser les membres protected et public de la classe A ClassA a1 = new ClassA(1,9); ClassB b1 = new ClassB(1,0,10); ClassA b2 = new ClassB(2,9,3); cout << b1 >getval1()<<","; cout << b1 >getval2()<<","; cout << b1 >getval3()<<endl; cout << b2 >getval3()<<endl; // ERREUR: membre inconnu Héritage 9

Visibilité de la classe mère Les membres de la classe mère peuvent avoir une visibilité différente de celle qu ils avaient dans cette classe La visibilité est définie dans l héritage public l héritage est visible depuis l extérieur, les instances de la classe fille sont partout des instances de la classe mère. Les membres ont la même visibilité que dans la classe mère protected l héritage n est visible que dans la classe et dans les classes qui en héritent. Les membres protected et public de la classe mère deviennent protected dans la classe fille. private cet héritage n est visible que dans cette unique classe et tous les membres sont private. Héritage 10

Visibilité de la classe mère (Cont.) class A {... ; class B : public A {... ; class C : protected A {... ; class D : private A {... ; int main() { B b; C c; D d; A ptr; ptr = &B; // OK ptr = &C; // Erreur (ca ne marchera que dans C et toutes ses derivees ptr = &D; // Erreur (ca ne marchera que dans D Héritage 11

Construction Chaque instance de la classe fille est aussi une instance de la classe mère Le constructeur de la classe mère est appelé par le constructeur de la classe fille // Constructeur de la classe B // Les deux premiers parametres sont directement passes a // la classe mere ClassB::ClassB(int v1, int v2, int v3):classa(v1,v2){ val3 = v3; // Le constructeur en recopie fait aussi appel // au constructeur en recopie de la classe mere ClassB::ClassB(const ClassB& b):classa(b){... Constructeur en recopie est appelé à chaque = ou passage de paramètre par copie. Héritage 12

Surcharge de méthode Les méthodes définies dans la classe mère peuvent être redéfinies dans la classe fille La méthode appelée est celle correspondant au type du pointeur ou de la variable. Permet de modifier le comportement de la classe fille Héritage 13

Surcharge de méthode (Cont.) class A {... public: void f(int); ; class B : public A {... public: void f(int); ; int main() { B b; b.f(0); // Appel de B::f A ptra = &b; ptra >f(0); // Appel de A::f au lieu de B::f ; Héritage: Surcharge de méthode 14

Surcharge de méthode (Cont.) class ClassA {... public: int computetotal(); ; class ClassB : public ClassA {... public: int computetotal(); ; int main() { ClassA c1 = new ClassA(1,0); ClassB c2 = new ClassB(2,0,3); ClassB c3 = new ClassB(1,0,3); ClassA c4 = c3; cout << c1 >getval1() << endl; cout << c1 >computetotal() << endl; Héritage: Surcharge de méthode 15

Surcharge d opérateur C++ offre la possiblité de surcharger les opérateurs Par exemple: Opérateurs arithmétiques : operator+, operator-,operator*,operator/, Opérateurs d accés (read/write): operator[], Opérateur de flux de sortie: operator>> Héritage: Surcharge d opérateur 16

Exemple classe des complexes Opérateurs internes à la classe, class Complex{ public: Complex operator+(complex& c2); Complex operator (Complex& c2); Complex operator (Complex& c2); Complex operator+(double d);... Définitions des opérateurs peuvent utiliser this Complex Complex::operator+(Complex& c2){ return Complex(this >getreal()+c2.getreal(), this >getimaginary()+c2.getimaginary()); Complex Complex::operator+(double d){ return Complex(this >getreal()+d,this >getimaginary());... Héritage: Surcharge d opérateur 17

Exemple classe des complexes Opérateurs externes à la classe (pas de this possible) ostream& operator<<(ostream& s, const Complex& z); Complex operator+(double d, const Complex& c); Définition des opérateurs Complex operator+(double d, const Complex& c){ return Complex(c.getReal()+d,c.getImaginary()); ostream& operator<<(ostream& s, const Complex& z){ return s <<"(" <<z.getreal() <<","<<z.getimaginary()<<")"; Héritage: Surcharge d opérateur 18

Méthodes virtuelles On a vu: en cas de surcharge d une méthode ou d un opérateur: La méthode utilisée dépend du type du pointeur et pas de la classe de l instance. Souhait: Que l on puisse redéfinir une méthode dans une sous-classe et que cette méthode soit executée Technique: méthode virtuelle Une méthode virtuelle est définie dans une classe Cette méthode est surchargée dans une classe fille Si une instance de la classe fille est affectée à un pointeur de la classe mère, c est la méthode de la classe fille qui est appelée. Héritage: Métodes virtuelles 19

Exemple 1 lass A {... public: virtual void f(int); ; class B : public A {... public: void f(int); ; int main() { B b; b.f(0); // Appel de B::f A ptra = &b; ptra >f(0); // Appel de B::f ; Héritage: Métodes virtuelles 20

Exemple 2 class ClassA {... virtual int anotherresult();... class ClassB : public ClassA {... int anotherresult();...; int main(int argc,char argv[]) { ClassB c3 = new ClassB(1,0,3); ClassA c4 = c3; // Resultat different (methode non virtuelle) cout << "Class B=" <<c3 >computetotal(); cout << " ClassA="<< c4 >computetotal() << endl; // Meme resultat (methode virtuelle) cout << "Class B=" <<c3 >anotherresult(); cout << " ClassA="<< c4 >anotherresult() << endl; Héritage: Métodes virtuelles 21

Destructeur Le destructeur de la classe mère est appelé automatiquement après le destructeur de la classe fille. Les appels aux destructeurs se font dans l ordre inverse des appels aux constructeurs. Si une classe contient une méthode virtuelle, son destructeur doit aussi être virtuel Si un pointeur de la classe mère référence un objet de la classe fille, Il faut que ce soit le destructeur de la classe fille qui soit appelé et pas le destructeur de la classe mère. Il y a plus de mémoire allouée pour une instance de la classe fille, si celle-ci n est pas désaluée : risque de mémory leak. Héritage: Destructeur 22

Méthode virtuelle pure / classe abstraite Une méthode peut être déclarée dans une classe mais non définie On l appelle alors virtuelle pure Une classe ayant une méthode virtuelle pure est dite: Classe Abstraite Une classe abstraite ne peut pas être instanciée Pour être instanciée, une classe fille doit implémenter la (ou les) méthode(s) virtuelle(s) pure(s). Héritage: Classe abstraite 23

Classe abstraite (Cont.) Example class ClassA {... virtual int methodx() = 0;... class ClassB : public ClassA {... int methodx();...; int main(int argc,char argv[]) { ClassB c3 = new ClassB(1,0,3); ClassA c4 = new ClassA(3,4); // illegal Héritage: Classe abstraite 24

Classe abstraite (Cont.) Classe abstraite: Usage Ne peut pas être instanciée Partiellement fini Décrit ce que doit faire la classe Ne décrit pas comment le faire Un contrat entre l utilisateur et le réalisateur des implémentations. L utilisateur d une telle classe peut programmer tout son code en utilisant la classe abstraite comme type. L utilisateur n a pas à savoir avec quelle implémentation il travaille. Les réalisateurs de la classe réelle doivent juste respecter le contrat. Héritage: Classe abstraite 25

Exemple: Gestion des salles de l Université Toutes les salles de l Université ont un numéro (unique) Deux sortes de salles à l Université Les bureaux (Offices) qui ont un propriétaire Les salles de classe (Classroom) qui ont un nombre de places assises et qui savent si elles contiennent un beamer. Trois classes: Room une classe de base (qui pourrait être abstraite mais ne l est pas) Classroom hérite de Room Office hérite de Room aussi Héritage: Exemple: Gestion des salles de l Université 26

Room.h class Room { public: Room(int number); int getnumber() const; void setnumber(int number); virtual std::string tostring() const; private: int number; ; Héritage: Exemple: Gestion des salles de l Université 27

Room.cpp Room::Room(int n){ Room::numberInstances++; this >number = n; Room::hm >insert(std::make_pair(n,this)); int Room::getNumber() const{ return this >number; void Room::setNumber(int n){ this >number = n; std::string Room::toString() const { std::ostringstream str; str <<"Number"<< this >number; return str.str(); Héritage: Exemple: Gestion des salles de l Université 28

Office.h class Office : public Room { public: Office(int number, std::string owner); std::string getowner() const; void setowner(string& v2); string tostring() const; private: string owner ; ; Héritage: Exemple: Gestion des salles de l Université 29

Office.cpp Office::Office(int number, string owner):room(number){ this >owner = owner; string Office::getOwner() const{ return this >owner; void Office::setOwner(string& owner){ this >owner = owner; string Office::toString() const { return Room::toString()+this >owner; Héritage: Exemple: Gestion des salles de l Université 30

Classroom.h class Classroom : public Room { public: Classroom(int number, int nbofseats, bool hasbeamer); int getnbofseats() const; void setnbofseats(int nbofseats); bool hasbeamer() const; void addbeamer(); void removebeamer(); std::string tostring() const; private: int nbofseats ; bool beamer; ; Héritage: Exemple: Gestion des salles de l Université 31

Classroom.cpp Classroom::Classroom(int number, int nbofseats, bool hasbeamer): Room(numb { this >nbofseats = nbofseats; this >beamer = hasbeamer; int Classroom::getnbOfSeats() const { return this >nbofseats; void Classroom::setNbOfSeats(int nbofseats) { this >nbofseats = nbofseats; bool Classroom::hasBeamer() const { return this >beamer; void Classroom::addBeamer() { this >beamer = true; void Classroom::removeBeamer() { this >beamer = false; std::string Classroom::toString() const { std::ostringstream str; str <<"Classroom"<< Room::toString() << ";"<< nbofseats; Héritage: Exemple: Gestion des salles de l Université 32

testentry.cpp int main(int argc,char argv[]) { Room c1 = new Room(1); Room c2 = new Classroom(101,50,true); Room c3 = new Classroom(102,45,false); Room c4 = new Classroom(103,30,false); Room c5 = new Office(104,"Hans Muster"); Room c6 = new Office(105,"Toto"); Room c7 = new Office(106,"E.Benoist"); cout << c4 >tostring() << endl; cout << c7 >tostring() << endl; Héritage: Exemple: Gestion des salles de l Université 33

Exercice numéro 3 Voir sur www.benoist.ch/courscpp/exercises.php Héritage: Exemple: Gestion des salles de l Université 34

Librairie Standard Templates (i.e. patrons) Strings Conteneurs / Itérateurs Librairie Standard 35

Templates Les classes contenant quelquechose, sont dépendantes de cette chose. Par exemple notre classe contenant des int (stack puis doubly linked list en exercice) Idée: mettre le type de la donnée de coté et écrire une classe générique Nous avons des classes dynamiques. La définition de cette classe contient une partie variable (le type). La classe (avec la définition de toutes ses méthodes) doit être incluse lors de la compilation. (et pas pendant l édition de liens) Librairie Standard: Templates 36

Templates: Exemple classe stack générique Nous reprenons notre stack d int dans laquelle nous remplaçons la partie variable Nous voulons pouvoir utiliser la classe comme ceci int main(int argc,char argv[]) { LinkedList<int> l2 = new LinkedList<int>(); l2 >push(0); l2 >push(1); l2 >push(2); while(l2 >size() > 0){ cout << l2 >pop()<< ", "; cout << endl; Librairie Standard: Templates 37

private: Type val; Node<Type> next; ; Librairie Standard: Templates 38 Node.h Template (Cont.) template <class Type> class Node { public: Node(Type val, Node<Type> next); Type getval(); void setval(type i); Node<Type> getnext(); void setnext(node<type> next);

Node.cpp Template (Cont.) template <class Type> Node<Type>::Node(Type val, Node<Type> next){ this >val = val; this >next = next; template <class Type> Type Node<Type>::getVal(){ return this >val; template <class Type> void Node<Type>::setVal(Type i){ this >val=i; template <class Type> Node<Type> Node<Type>::getNext(){ return this >next; template <class Type> void Node<Type>::setNext(Node<Type> next){ Librairie Standard: Templates 39

LinkedList.h Template (Cont.) #include "Node.h" #include "Node.cpp" template <class Type> class LinkedList { public: LinkedList(); ~LinkedList(); void push(type val); Type pop(); int size(); private: Node<Type> firstnode; Type number; ; Librairie Standard: Templates 40

LinkedList.cpp #include "LinkedList.h" template <class T> LinkedList<T>::LinkedList(){ firstnode = 0; number=0; template <class T> LinkedList<T>::~LinkedList<T>(){ while(size()!=0){ pop(); template <class Type> void LinkedList<Type>::push(Type val){ number++; firstnode = new Node<Type>(val,firstNode); return; template <class Type> Type LinkedList<Type>::pop(){ Librairie Standard: Templates 41

Strings La bibliothèque standard offre un support pour les chaînes de caractères. les chaînes en C sont des char* Fin de chaine donnée avec caractère 0. Allocation dynamique assez délicate. En C++ la chaîne est stockée sous forme d objet string Nous devons charger la bibliothèque <string> pour pouvoir l utiliser Librairie Standard: Strings 42

Méthodes pratiques des strings length() retourne la longueur de la string operator+ concaténation de la string avec des strings ou des chars. operator>> opérateur de flux d entrée operator<< opérateur de flux de sortie operator[] accés aux caractères à l aide de leur index. empty() teste si la string est vide append(const string& str) concatène str à la string this Librairie Standard: Strings 43

String exemples #include <string> class Office : public Room { public: Office(int number, std::string owner); std::string getowner() const; void setowner(std::string& v2); std::string tostring() const; private: std::string owner ; ; Librairie Standard: Strings 44

Suite de l exemple std::string Office::toString() const { return Room::toString()+this >owner; Librairie Standard: Strings 45

Conteneurs/Iterateurs Mode de stockage générique des éléments Permet de disposer de Structures de données standard sans programmer vector structure objet représentant un array list structure chainée de liste map donnée regroupant une cle et une valeur... Librairie Standard: Conteneurs / Iterateurs 46

Vector La classe vector correspond à un array d éléments Accés efficace à l aide d un indice Insertion et effacage difficile au milieu Offre de multiple fonctionnalités en plus Opérateur [] pour avoir une syntaxe proche des arrays methode push_back(elem) permet d inserer dans le vecteur (gestion automatique de la mémoire) méthode size() retourne le nombre d éléments contenus dans la structure. Librairie Standard: Conteneurs / Iterateurs 47

Vector: Exemple vector<int> v1; v1.push_back(1); v1.push_back(2); v1.push_back(3); v1.push_back(4); for(int i=0;i<v1.size();i++){ cout << v1[i] << endl; Librairie Standard: Conteneurs / Iterateurs 48

Iterator Objet de type pointeur sur un élément d un conteneur Utilisé pour visiter une structure conteneur ContainerType C; // Any standard container type, // like std::list<sometype> //for (ContainerType::iterator it = C.begin(); it!= C.end(); ++it){ // for mutable iterator (if you need to modify elements) for (ContainerType::const_iterator it = C.begin(); it!= C.end(); ++it) { std::cout << it << std::endl; Librairie Standard: Conteneurs / Iterateurs 49

Iterator: Example vector<int> v1; v1.push_back(1);... for (vector<int>::const_iterator it = v1.begin(); it!= v1.end(); ++it) { cout << it << std::endl; vector<string> v2; v2.push_back("aa");... for (vector<string>::const_iterator it = v2.begin(); it!= v2.end(); ++it) { cout << it << std::endl; Librairie Standard: Conteneurs / Iterateurs 50

Map Structure de liste associative On associe une clé à une valeur Template utilise deux types: <cle,valeur> Méthodes pour insérer, tester et retourner les éléments stockés: insert(make_pair(key,value)) insère une paire dans la map find(key) retourne la paire correspondant à la clé donnée la paire retournée peut être à nouveau scindée en deux le membre first contient la clé le membre second contient la valeur. Librairie Standard: Conteneurs / Iterateurs 51

Map: Exemple Dans notre exemple de gestion des pièces, nous voulons une méthode statique pour retrouver une Room connaissant son numéro static Room getroom(int n); Nous définissons donc une variable de classe (static) qui contiendra les éléments clé: int valeur: Room* class Room {... private: static std::map<int,room > hm; Librairie Standard: Conteneurs / Iterateurs 52

Map: Exemple (Suite) Nous définissons la méthode d accés Room Room::getRoom(int n){ std::map<int,room > hm1 = Room::hm; return hm1 >find(n) >second; Librairie Standard: Conteneurs / Iterateurs 53

Exercice numéro 4 Voir sur www.benoist.ch/courscpp/exercises.php Librairie Standard: Conteneurs / Iterateurs 54