Introduction à C++ pour programmeurs C
|
|
- Martine Bertrand
- il y a 8 ans
- Total affichages :
Transcription
1 SITEL - Université de Neuchâtel Introduction à C++ pour programmeurs C Dr. E. Benoist Novembre
2 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
3 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
4 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
5 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
6 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
7 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
8 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
9 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
10 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
11 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
12 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
13 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
14 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
15 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
16 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
17 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
18 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
19 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
20 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
21 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
22 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
23 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
24 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
25 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
26 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
27 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
28 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
29 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
30 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
31 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
32 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
33 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
34 Exercice numéro 3 Voir sur Héritage: Exemple: Gestion des salles de l Université 34
35 Librairie Standard Templates (i.e. patrons) Strings Conteneurs / Itérateurs Librairie Standard 35
36 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
37 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
38 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);
39 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
40 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
41 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
42 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
43 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
44 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
45 Suite de l exemple std::string Office::toString() const { return Room::toString()+this >owner; Librairie Standard: Strings 45
46 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
47 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
48 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
49 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
50 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
51 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
52 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
53 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
54 Exercice numéro 4 Voir sur Librairie Standard: Conteneurs / Iterateurs 54
Prénom : Matricule : Sigle et titre du cours Groupe Trimestre INF1101 Algorithmes et structures de données Tous H2004. Loc Jeudi 29/4/2004
Questionnaire d'examen final INF1101 Sigle du cours Nom : Signature : Prénom : Matricule : Sigle et titre du cours Groupe Trimestre INF1101 Algorithmes et structures de données Tous H2004 Professeur(s)
Plus en détailUne introduction à Java
Une introduction à Java IFT 287 (Semaine 1) UNIVERSITÉ DE SHERBROOKE 1 Java - Historique Développé par Sun Microsystems en 1994 Inventeur James Gosling (canadien!) Objectif langage sûr (fortement typé)
Plus en détailLicence Bio Informatique Année 2004-2005. Premiers pas. Exercice 1 Hello World parce qu il faut bien commencer par quelque chose...
Université Paris 7 Programmation Objet Licence Bio Informatique Année 2004-2005 TD n 1 - Correction Premiers pas Exercice 1 Hello World parce qu il faut bien commencer par quelque chose... 1. Enregistrez
Plus en détailCours de C++ François Laroussinie. 2 novembre 2005. Dept. d Informatique, ENS de Cachan
Cours de C++ François Laroussinie Dept. d Informatique, ENS de Cachan 2 novembre 2005 Première partie I Introduction Introduction Introduction Algorithme et programmation Algorithme: méthode pour résoudre
Plus en détailProgrammer en JAVA. par Tama (tama@via.ecp.fr( tama@via.ecp.fr)
Programmer en JAVA par Tama (tama@via.ecp.fr( tama@via.ecp.fr) Plan 1. Présentation de Java 2. Les bases du langage 3. Concepts avancés 4. Documentation 5. Index des mots-clés 6. Les erreurs fréquentes
Plus en détailLMI 2. Programmation Orientée Objet POO - Cours 9. Said Jabbour. jabbour@cril.univ-artois.fr www.cril.univ-artois.fr/~jabbour
LMI 2 Programmation Orientée Objet POO - Cours 9 Said Jabbour jabbour@cril.univ-artois.fr www.cril.univ-artois.fr/~jabbour CRIL UMR CNRS 8188 Faculté des Sciences - Univ. Artois Février 2011 Les collections
Plus en détailPour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère
L'héritage et le polymorphisme en Java Pour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère En java, toutes les classes sont dérivée de la
Plus en détailas Architecture des Systèmes d Information
Plan Plan Programmation - Introduction - Nicolas Malandain March 14, 2005 Introduction à Java 1 Introduction Présentation Caractéristiques Le langage Java 2 Types et Variables Types simples Types complexes
Plus en détailJava Licence Professionnelle 2009-2010. Cours 7 : Classes et méthodes abstraites
Java Licence Professionnelle 2009-2010 Cours 7 : Classes et méthodes abstraites 1 Java Classes et méthodes abstraites - Le mécanisme des classes abstraites permet de définir des comportements (méthodes)
Plus en détailGénie Logiciel I. Cours VI - Typage statique / dynamique, fonctions virtuelles et classes abstraites, flots d entrées / sorties, et string
Génie Logiciel I Cours VI - Typage statique / dynamique, fonctions virtuelles et classes abstraites, flots d entrées / sorties, et string Nicolas Kielbasiewicz C.D.C.S.P./I.S.T.I.L./I.C.J. Filière M.A.M.
Plus en détailTP1 : Initiation à Java et Eclipse
TP1 : Initiation à Java et Eclipse 1 TP1 : Initiation à Java et Eclipse Systèmes d Exploitation Avancés I. Objectifs du TP Ce TP est une introduction au langage Java. Il vous permettra de comprendre les
Plus en détailCours 1: Java et les objets
Ressources Les interface homme-machine et le langage Java DUT première année Henri Garreta, Faculté des Sciences (Luminy) Cyril Pain-Barre & Sébastien Nedjar, IUT d Aix-Marseille (Aix) Cours 1: infodoc.iut.univ-aix.fr/~ihm/
Plus en détailTP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile
TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile Dans ce TP, vous apprendrez à définir le type abstrait Pile, à le programmer en Java à l aide d une interface
Plus en détailHéritage presque multiple en Java (1/2)
Héritage presque multiple en Java (1/2) Utiliser deux classes ou plus dans la définition d'une nouvelle classe peut se faire par composition. class Etudiant{ int numero; Diplome d; float passeexamen(examen
Plus en détailChapitre V. Les classes : Object, Vector, etc.
Chapitre V Les classes de base Les classes : Object, Vector, etc. Plan La classe Object Les collections La classe ArrayList La classe Vector Les classes Wrappers Les classes String et StringBuffer La classe
Plus en détailINFO-F-105 Language de programmation I Séance VI
INFO-F-105 Language de programmation I Séance VI Jérôme Dossogne Année académique 2008 2009 Un grand merci à Yves Roggeman pour ses relectures et remarques des codes et commentaires qui ont contribuées
Plus en détailProgrammation avec des objets : Cours 7. Menu du jour
1 Programmation avec des objets : Cours 7 Menu du jour 1. Retour sur la classe Liste 2. Précisions sur l interface 3. Difficultés dans le cas d erreurs 4. Soulever des exceptions 5. Utilisation des Listes
Plus en détailPackage Java.util Classe générique
Package Java.util Classe générique 1 Classe Vector La taille est dynamique: dès qu un tableau vectoriel est plein, sa taille est doublée, triplée, etc. automatiquement Les cases sont de type Object add(object
Plus en détailGénéralités sur le Langage Java et éléments syntaxiques.
Généralités sur le Langage Java et éléments syntaxiques. Généralités sur le Langage Java et éléments syntaxiques....1 Introduction...1 Genéralité sur le langage Java....1 Syntaxe de base du Langage...
Plus en détailEncapsulation. L'encapsulation consiste à rendre les membres d'un objet plus ou moins visibles pour les autres objets.
Encapsulation L'encapsulation consiste à rendre les membres d'un objet plus ou moins visibles pour les autres objets. La visibilité dépend des membres : certains membres peuvent être visibles et d'autres
Plus en détailFacultés Universitaires Notre-Dame de la Paix. Conception et Programmation Orientées- Object
Facultés Universitaires Notre-Dame de la Paix Conception et Programmation Orientées- Object 2008-2009 RÉSUMÉ PRATIQUE... 4 CLASSE OBJET... 4 NOTION D HÉRITAGE... 4 LE POLYMORPHISME... 5 LES CLASSES ABSTRAITES...
Plus en détailTD/TP PAC - Programmation n 3
Université Paris Sud Licence d informatique/iup-miage2 - Année 2004-2005 auteur : Frédéric Vernier semaine : 11-16 octobre 2004 conditions : sur machine avec les outils standards java web: http://vernier.frederic.free.fr/indexpac.html
Plus en détailPolymorphisme, la classe Object, les package et la visibilité en Java... 1
Polymorphisme, la classe Object, les package et la visibilité en Java. Polymorphisme, la classe Object, les package et la visibilité en Java.... 1 Polymorphisme.... 1 Le DownCast... 4 La Classe Object....
Plus en détailLangage et Concepts de Programmation Objet. 1 Attributs et Méthodes d instance ou de classe. Travaux Dirigés no2
Langage et Concepts de Programmation Objet Travaux Dirigés no2 Pôle Informatique École Nationale Supérieure des Mines de St-Etienne Vous trouverez plus de détails sur les concepts abordés lors de ce TD
Plus en détailRAPPELS SUR LES METHODES HERITEES DE LA CLASSE RACINE Object ET LEUR SPECIALISATION (i.e. REDEFINITION)
CLASSE RACINE Object ancêtre de toutes les classes RAPPELS SUR LES METHODES HERITEES DE LA CLASSE RACINE Object ET LEUR SPECIALISATION (i.e. REDEFINITION) définit donc des méthodes héritées par toutes
Plus en détailC++ 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
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 des objets d'une classe Utilisation d'une classe Droit
Plus en détail4. Groupement d objets
Conception objet en Java avec BlueJ une approche interactive 4. Groupement d objets Collections et itérateurs David J. Barnes, Michael Kölling version française: Patrice Moreaux Rédigé avec 1.0 Principaux
Plus en détailGénie Logiciel avec Ada. 4 février 2013
Génie Logiciel 4 février 2013 Plan I. Généralités II. Structures linéaires III. Exceptions IV. Structures arborescentes V. Dictionnaires I. Principes II. Notions propres à la POO I. Principes Chapitre
Plus en détailLangage et Concepts de ProgrammationOrientée-Objet 1 / 40
Déroulement du cours Introduction Concepts Java Remarques Langage et Concepts de Programmation Orientée-Objet Gauthier Picard École Nationale Supérieure des Mines de Saint-Étienne gauthier.picard@emse.fr
Plus en détailCours intensif Java. 1er cours: de C à Java. Enrica DUCHI LIAFA, Paris 7. Septembre 2009. Enrica.Duchi@liafa.jussieu.fr
. Cours intensif Java 1er cours: de C à Java Septembre 2009 Enrica DUCHI LIAFA, Paris 7 Enrica.Duchi@liafa.jussieu.fr LANGAGES DE PROGRAMMATION Pour exécuter un algorithme sur un ordinateur il faut le
Plus en détailChapitre VI- La validation de la composition.
Chapitre VI- La validation de la composition. Objectifs du chapitre : Expliquer les conséquences de l utilisation de règles de typage souples dans SEP. Présenter le mécanisme de validation des connexions
Plus en détailIntroduction à C++ et à wxwidgets
Introduction à C++ et à wxwidgets Master IGC 1ère année Année universitaire 2011/2012 Christophe Renaud Version 1.5 19/09/2011 Introduction Objectifs du cours Introduction au langage objet C++ Introduction
Plus en détailP 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 )
P r ob lé m a t iq u e d e la g é n é r icit é les versions de Java antérieures à 1.5 permettaient de créer des classes de structures contenant n'importe quels types d'objet : les collections (classes
Plus en détailJava Licence Professionnelle CISII, 2009-2010. Cours 2 : Classes et Objets
Licence Professionnelle CISII, 2009-2010 Cours 2 : Classes et Objets 1 Classes et Objets Objectifs des LOO : - Manipuler des objets - Découper les programmes suivant les types des objets manipulés - Regrouper
Plus en détailet Programmation Objet
FACULTE POLYTECHNIQUE DE MONS Service d Informatique et Programmation Objet Mohammed Benjelloun 2 ème Bachelier Année académique 2008-2009 Table des matières Avant-propos--------------------------------------------------------------------------
Plus en détailBases Java - Eclipse / Netbeans
Institut Galilée PDJ Année 2014-2015 Master 1 Environnements Java T.P. 1 Bases Java - Eclipse / Netbeans Il existe plusieurs environnements Java. Il est ESSENTIEL d utiliser la bonne version, et un environnement
Plus en détailApprendre la Programmation Orientée Objet avec le langage Java (avec exercices pratiques et corrigés)
Introduction à la POO 1. Histoire de la POO 9 2. Historique du 12 La conception orientée objet 1. Approche procédurale et décomposition fonctionnelle 13 2. La transition vers l'approche objet 14 3. Les
Plus en détailInitiation à JAVA et à la programmation objet. raphael.bolze@ens-lyon.fr
Initiation à JAVA et à la programmation objet raphael.bolze@ens-lyon.fr O b j e c t i f s Découvrir un langage de programmation objet. Découvrir l'environnement java Découvrir les concepts de la programmation
Plus en détailClasses et Objets en Ocaml.
Classes et Objets en Ocaml. Didier Rémy 2001-2002 http://cristal.inria.fr/ remy/mot/2/ http://www.enseignement.polytechnique.fr/profs/informatique/didier.remy/mot/2/ Cours Exercices Slide 1 1. Objets 2.
Plus en détailClasse Interne, Anonyme & Enumération
Java Avancé Classe Interne, Anonyme & Enumération Rémi Forax forax@univ-mlv.fr 1 Rappel Nous nous intéressons aujourd'hui à deux formes de type abstrait en Java Les interfaces Les classes abstraites Les
Plus en détailProgrammation Par Objets
Programmation Par Objets Structures de données package java.util B. Carré Polytech Lille 1 Tableaux et structures de données Tableaux «Objets» taille fixe type des éléments : primitif (homogène) ou objets
Plus en détailLangage Java. Classe de première SI
Langage Java Table des matières 1. Premiers pas...2 1.1. Introduction...2 1.2. Mon premier programme...2 1.3. Les commentaires...2 2. Les variables et les opérateurs...2 3. La classe Scanner...3 4. Les
Plus en détailProgrammation Orientée Objet
Programmation Orientée Objet Bertrand Estellon Département Informatique et Interactions Aix-Marseille Université 21 octobre 2014 Bertrand Estellon (DII AMU) Programmation Orientée Objet 21 octobre 2014
Plus en détailAuto-évaluation Programmation en Java
Auto-évaluation Programmation en Java Document: f0883test.fm 22/01/2013 ABIS Training & Consulting P.O. Box 220 B-3000 Leuven Belgium TRAINING & CONSULTING INTRODUCTION AUTO-ÉVALUATION PROGRAMMATION EN
Plus en détailCette application développée en C# va récupérer un certain nombre d informations en ligne fournies par la ville de Paris :
Développement d un client REST, l application Vélib 1. Présentation L application présentée permet de visualiser les disponibilités des vélos et des emplacements de parking à la disposition des parisiens
Plus en détailObjets et Programmation. origine des langages orientés-objet
Objets et Programmation origine des langages orientés-objet modularité, encapsulation objets, classes, messages exemples en Java héritage, liaison dynamique G. Falquet, Th. Estier CUI Université de Genève
Plus en détailExceptions. 1 Entrées/sorties. Objectif. Manipuler les exceptions ;
CNAM NFP121 TP 10 19/11/2013 (Séance 5) Objectif Manipuler les exceptions ; 1 Entrées/sorties Exercice 1 : Lire un entier à partir du clavier Ajouter une méthode readint(string message) dans la classe
Plus en détail2. Comprendre les définitions de classes
Conception objet en Java avec BlueJ une approche interactive 2. Comprendre les définitions de classes Analyser le contenu des classes David J. Barnes, Michael Kölling version française: Patrice Moreaux
Plus en détailProgrammation par les Objets en Java
Programmation par les Objets en Java Najib TOUNSI Les classes en Java (TD 3) I. Notion de classe I.1 Classe, champs, méthodes, instanciation, this, private vs. public. Créer une classe Point (coordonnée
Plus en détailCOMPARAISONDESLANGAGESC, C++, JAVA ET
REPUBLIQUE DU BENIN *******@******* MINISTERE DE L ENSEIGNEMENT SUPERIEUR ET DE LA RECHERCHE SCIENTIFIQUE(MESRS) *******@******* UNIVERSITE D ABOMEY CALAVI(UAC) *******@******* ECOLE POLYTECHNIQUE D ABPOMEY
Plus en détailStructure d un programme et Compilation Notions de classe et d objet Syntaxe
Cours1 Structure d un programme et Compilation Notions de classe et d objet Syntaxe POO 1 Programmation Orientée Objet Un ensemble d objet qui communiquent Pourquoi POO Conception abstraction sur les types
Plus en détailPremiers Pas en Programmation Objet : les Classes et les Objets
Chapitre 2 Premiers Pas en Programmation Objet : les Classes et les Objets Dans la première partie de ce cours, nous avons appris à manipuler des objets de type simple : entiers, doubles, caractères, booléens.
Plus en détailUtiliser Java sans BlueJ
Conception objet en Java avec BlueJ une approche interactive Utiliser Java sans BlueJ Michael Kölling version française: Patrice Moreaux Rédigé avec 1.0 Conception objet en Java avec BlueJ une approche
Plus en détailConventions d écriture et outils de mise au point
Logiciel de base Première année par alternance Responsable : Christophe Rippert Christophe.Rippert@Grenoble-INP.fr Introduction Conventions d écriture et outils de mise au point On va utiliser dans cette
Plus en détailTD/TP PAC - Programmation n 3
Université Paris Sud Licence d informatique/iup-miage2 Année 2004-2005 Auteur : Frédéric Vernier Semaine : 11-16 octobre 2004 Conditions : sur machine avec les outils standards java web: http://vernier.frederic.free.fr/indexpac.html
Plus en détailCorrigés des premiers exercices sur les classes
Corrigés des premiers exercices sur les classes Exercice 2.1.1 utilisation d une classe Voici le texte d une classe représentant de façon sommaire un compte bancaire et les opérations bancaires courantes.
Plus en détail30.avr.10 Présentation miniprojet. 9.mars.10 Cours 3 4.mai.10 Cours C++ 1. 16.mars.10 Cours 4 11.mai.10 Cours C++ 2
2ème partie de cours: 23.fév.10 Cours 1 20.avr.10 TEST 24.fév.10 TP1 21.avr.10 miniprojet 26.fév.10 TP réserve 23.avr.10 miniprojet 2.mars.10 Cours 2 27.avr.10 Présentation miniprojet 3.mars.10 TP2 28.avr.10
Plus en détailTraduction des Langages : Le Compilateur Micro Java
BARABZAN Jean-René OUAHAB Karim TUCITO David 2A IMA Traduction des Langages : Le Compilateur Micro Java µ Page 1 Introduction Le but de ce projet est d écrire en JAVA un compilateur Micro-Java générant
Plus en détailINITIATION AU LANGAGE JAVA
INITIATION AU LANGAGE JAVA I. Présentation 1.1 Historique : Au début des années 90, Sun travaillait sur un projet visant à concevoir des logiciels simples et performants exécutés dans des PDA (Personnal
Plus en détailIntroduction à Java. Matthieu Herrb CNRS-LAAS. Mars 2014. http://homepages.laas.fr/matthieu/cours/java/java.pdf
Introduction à Java Matthieu Herrb CNRS-LAAS http://homepages.laas.fr/matthieu/cours/java/java.pdf Mars 2014 Plan 1 Concepts 2 Éléments du langage 3 Classes et objets 4 Packages 2/28 Histoire et motivations
Plus en détailPROGRAMMATION PAR OBJETS
PROGRAMMATION PAR OBJETS Java Environnement et constructions spécifiques Walter Rudametkin Maître de Conférences Bureau F011 Walter.Rudametkin@polytech-lille.fr B. Carré Polytech Lille 2 Java (Sun 1995)
Plus en détailJava 1.5 : principales nouveautés
Cours 6 - TEP - UPMC - 2008/2009 p. 1/34 Java 1.5 : principales nouveautés classes paramétrées : generics encapsulation des valeurs de types primitifs : auto[un]boxing itération sur les boucles types énumérés
Plus en détailJava c est quoi? Java pourquoi?
Grandes lignes du cours Cours JAVA : Le bases du langage Java. Version 3.02 Julien Sopena 1 1 julien.sopena@lip6.fr Équipe REGAL - INRIA Rocquencourt LIP6 - Université Pierre et Marie Curie Licence professionnelle
Plus en détailProgrammation Orientée Objet application au langage Java Version Novembre 2007
Programmation Orientée Objet application au langage Java Version Novembre 2007 Mickaël BARON - 2007 mailto:baron.mickael@gmail.com ou mailto:mickael.baron@serli.com SERLI informatique SERLI : www.serli.com
Plus en détailMachines virtuelles fonctionnelles (suite) Compilation ML Java
Machines virtuelles fonctionnelles (suite) Compilation ML Java Cours de Compilation Avancée (MI190) Benjamin Canou Université Pierre et Maire Curie Année 2011/2012 Semaine 3 Machines virtuelles fonctionnelles
Plus en détailUtilisation d objets : String et ArrayList
Chapitre 6 Utilisation d objets : String et ArrayList Dans ce chapitre, nous allons aborder l utilisation d objets de deux classes prédéfinies de Java d usage très courant. La première, nous l utilisons
Plus en détailClasse ClInfoCGI. Fonctions membres principales. Gestion des erreurs
Utilisation des classes de PourCGI par Michel Michaud, version 2002-11-23 Les fichiers PourCGI.h et PourCGI.cpp rendent disponibles deux classes et une fonction libre qui permettent de faire facilement
Plus en détailTP, première séquence d exercices.
TP, première séquence d exercices. Benoît Valiron benoit.valiron@lipn.univ-paris13.fr 7 novembre 2010 Introduction Vous écrirez les réponses aux questions courtes sur une feuille à rendre à la fin de la
Plus en détailProgrammation Orientée Objet Java
Programmation Orientée Objet Java Bertrand Estellon Département Informatique et Interactions Aix-Marseille Université 12 novembre 2014 Bertrand Estellon (DII AMU) Programmation Orientée Objet Java 12 novembre
Plus en détailProgrammation MacOSX / ios
Programmation MacOSX / ios Master Ingénierie Informatique 2011-2012 Jean-Baptiste.Yunès@liafa.jussieu.fr deux extensions objets de C : C++ (Stroustrup) Objective-C (Cox & Love) ajout de constructions à
Plus en détailTp 1 correction. Structures de données (IF2)
Tp 1 correction Structures de données (IF2) Remarque générale : compilez et exécutez le code au-fur-et-à mesure de son écriture. Il est plus facile de corriger une petite portion de code délimitée que
Plus en détailTypes d applications pour la persistance. Outils de développement. Base de données préexistante? 3 modèles. Variantes avec passerelles
Types d applications pour la persistance Université de Nice Sophia-Antipolis Version 0.9 28/8/07 Richard Grin Toutes les applications n ont pas une complexité qui nécessite une architecture n- tiers Ce
Plus en détailCours de Programmation 2
Cours de Programmation 2 Programmation à moyenne et large échelle 1. Programmation modulaire 2. Programmation orientée objet 3. Programmation concurrente, distribuée 4. Programmation monadique 5. Les programmes
Plus en détailApprendre Java en 154 minutes
Apprendre Java en 154 minutes Tutorial Java 1.6 - HESB-TI Stéphanie Calderara José R. Beuret Quentin Cosendey Mai 2008 Table des matières 1 Objet, classe et modificateur 3 1.1 Le premier pas..........................
Plus en détailDiagramme de classes
Diagramme de classes Un diagramme de classes décrit les classes et leurs relations (associations, généralisation/spécialisation, ). classe association méthodes attributs héritage Diagramme de classes :
Plus en détailTD3: tableaux avancées, première classe et chaînes
TD3: tableaux avancées, première classe et chaînes de caractères 1 Lestableaux 1.1 Élémentsthéoriques Déclaration des tableaux Pour la déclaration des tableaux, deux notations sont possibles. La première
Plus en détailInformatique III: Programmation en C++
Informatique III: Programmation en C++ Listes haînées Lundi 9 Janvier 2006 1 2 Introdution Les listes hainées permettent de stoker un nombre d objets qui n a pas besoin d être spéifié a priori. Rajouter
Plus en détailGénéricité. en Java. (polymorphisme paramétrique) Philippe GENOUD UJF Janvier 2015 1
(polymorphisme paramétrique) en Java Philippe GENOUD UJF Janvier 2015 1 Motivations Supposons que l'on développe du code pour gérer une file d'attente (FIFO First In First Out) et que l'on veuille utiliser
Plus en détailINTRODUCTION A JAVA. Fichier en langage machine Exécutable
INTRODUCTION A JAVA JAVA est un langage orienté-objet pur. Il ressemble beaucoup à C++ au niveau de la syntaxe. En revanche, ces deux langages sont très différents dans leur structure (organisation du
Plus en détailPrésentation. Au programme. Fonctionnement. A l issue de ce module vous devriez...
Au programme Conception Orientée Objet Jean-Christophe Routier Licence mention Informatique Université Lille 1 Présentation L UE COO est le prolongement immédiat de l UE POO du S4 informatique. cf. http://portail.fil.univ-lille1.fr/portail/ls4/poo
Plus en détailDéveloppement Logiciel
Développement Logiciel Éxamen session 1-2012-2013 (Vendedi 25 mai, 9h-11h) Seuls les documents liés directement au cours sont autorisés (comme dit sur le site) : sujets de TD, notes de cours, notes personnelles
Plus en détailINITIATION AU LANGAGE C SUR PIC DE MICROSHIP
COURS PROGRAMMATION INITIATION AU LANGAGE C SUR MICROCONTROLEUR PIC page 1 / 7 INITIATION AU LANGAGE C SUR PIC DE MICROSHIP I. Historique du langage C 1972 : naissance du C dans les laboratoires BELL par
Plus en détailC++ Programmer. en langage. 8 e édition. Avec une intro aux design patterns et une annexe sur la norme C++11. Claude Delannoy
Claude Delannoy Programmer en langage C++ 8 e édition Avec une intro aux design patterns et une annexe sur la norme C++11 Groupe Eyrolles, 1993-2011. Groupe Eyrolles, 2014, pour la nouvelle présentation,
Plus en détail1/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)
1/4 Objectif de ce cours /4 Objectifs de ce cours Introduction au langage C - Cours Girardot/Roelens Septembre 013 Du problème au programme I passer d un problème exprimé en français à la réalisation d
Plus en détailProgrammation Orientée Objet
Université de Pau et des Pays de l Adour Institut Universitaire de Technologie des Pays de l Adour Département Réseaux et Télécommunications 371, rue du Ruisseau BP 201 40004 Mont-de-Marsan Cedex tél :
Plus en détail1 Définition d une classe en Java
Université Montpellier-II UFR des Sciences - Département Informatique Licence Informatique - Ingénierie Logicielle - Concepts et Outils de la modélisation et du développement de logiciel par et pour la
Plus en détailJAVA TD0. Prise en main du langage Environnement de base JAVA 1
JAVA TD0 Prise en main du langage Environnement de base JAVA 1 Mon premier programme public class HelloWorld { public static void main(string [] arg){ System.out.println("Hello, World!"); main(string []
Plus en détailAvertissement : Ce cours suppose la connaissance et la maîtrise du langage C CONTENU DU COURS BIBLIOGRAPHIE
Enseignement : GI 62 - C++ - Programmation orienté objet (C++) Objectif : Ce module se situe dans la continuité des modules (ii12) et UEL RAN Informatique et permet d'acquérir les bases de la modélisation
Plus en détailAnne Tasso. Java. Le livre de. premier langage. 10 e édition. Avec 109 exercices corrigés. Groupe Eyrolles, 2000-2015, ISBN : 978-2-212-14154-2
Anne Tasso Java Le livre de premier langage 10 e édition Avec 109 exercices corrigés Groupe Eyrolles, 2000-2015, ISBN : 978-2-212-14154-2 Table des matières Avant-propos Organisation de l ouvrage..............................
Plus en détailCentre CPGE TSI - Safi 2010/2011. Algorithmique et programmation :
Algorithmique et programmation : STRUCTURES DE DONNÉES A. Structure et enregistrement 1) Définition et rôle des structures de données en programmation 1.1) Définition : En informatique, une structure de
Plus en détailPlan Pédagogique du cours
Plan Pédagogique du cours Module: Programmation Orientée Objet Section : informatique Niveau : 3 ème niveau (gestion, industriel, réseau) Volume Horaire : 22,5 heures Cours Intégrés + 45 Travaux Pratiques
Plus en détailExercices sur les interfaces
Exercices sur les interfaces Fabrice Rossi 18 octobre 1999 1 Le type Object 1.1 Manipulations élémentaires Exercice 1.1 : Indiquer l affichage produit par le programme suivant : public class UpCast1 {
Plus en détailBrefs rappels sur la pile et le tas (Stack. / Heap) et les pointeurs
Brefs rappels sur la pile et le tas (Stack / Heap) et les pointeurs (exemples en C) v1.11 - Olivier Carles 1 Pile et Tas Mémoire allouée de manière statique Mémoire Allouée Dynamiquement variables locales
Plus en détailRemote Method Invocation Les classes implémentant Serializable
Parallélisme Architecture Eric Goubault Commissariat à l Energie Atomique Saclay Classe qui implémente la méthode distante (serveur): - dont les méthodes renvoient un objet serializable - ou plus généralement
Plus en détailCours d initiation à la programmation en C++ Johann Cuenin
Cours d initiation à la programmation en C++ Johann Cuenin 11 octobre 2014 2 Table des matières 1 Introduction 5 2 Bases de la programmation en C++ 7 3 Les types composés 9 3.1 Les tableaux.............................
Plus en détailProgrammation en C/C++
INSA de Lyon Département Génie Electrique Module IF1,IF3,IF4 Programmation en C/C++ Thomas Grenier Nicolas Ducros Tanneguy Redarce Lyon, le 3 mars 2015 2 / 63 Table des matières 1 Développement en C++
Plus en détailJava Licence Professionnelle CISII, 2009-10
Java Licence Professionnelle CISII, 2009-10 Cours 4 : Programmation structurée (c) http://www.loria.fr/~tabbone/cours.html 1 Principe - Les méthodes sont structurées en blocs par les structures de la programmation
Plus en détailGénéralités. javadoc. Format des commentaires. Format des commentaires. Caractères spéciaux. Insérer du code
Généralités javadoc Université de Nice - Sophia Antipolis Richard Grin Version 1.4.1 8/2/11 javadoc produit de la documentation en partant de commentaires particuliers insérés dans le code source des classes
Plus en détailProjet de programmation (IK3) : TP n 1 Correction
Projet de programmation (IK3) : TP n 1 Correction Semaine du 20 septembre 2010 1 Entrées/sorties, types de bases et structures de contrôle Tests et types de bases Tests et types de bases (entiers) public
Plus en détailChapitre 2. Classes et objets
Chapitre 2: Classes et Objets 1/10 Chapitre 2 Classes et objets Chapitre 2: Classes et Objets 2/10 Approche Orientée Objet Idée de base de A.O.O. repose sur l'observation de la façon dont nous procédons
Plus en détail