POO-L3 H. Fauconnier1 C) Méthodes: Redéfinition Un classe hérite des méthodes des classes ancêtres Elle peut ajouter de nouvelles méthodes Elle peut surcharger.

Slides:



Advertisements
Présentations similaires
Spécialisation/généralisation Héritage Polymorphisme
Advertisements

Introspection et Réflexion Manipulation dynamique de code Java.
Au programme du jour …. Livraison de code Organisation des répertoires et packages Ce que vous navez pas encore vraiment vu Constantes et variables de.
Programmer en JAVA par Tama
Programmation Objet en JAVA Cours 2 : Réutilisation, Héritage 1 Agrégation, composition, héritage, Hiérarchie, Constructeurs, Transtypage.
Leçon 3 : Héritage IUP 2 Génie Informatique
Chapitre IV Object, interfaces, classes imbriquées.
Chapitre III Héritage (début)
VI) exemple: Les astres…
Classes locales classes définies à l'intérieur d'un bloc de code,
Cours programmation-orientée objet en Java
Cours programmation-orientée objet en Java
Programmation orientée objet
POO-L3 H. Fauconnier1 Chapitre IV 1. classe Object, clonage 2. interfaces 3. classes internes et imbriquées.
Langage Oriente Objet Cours 4.
Cours du 19 octobre. POO-L3 H. Fauconnier2 E) Constructeurs et héritage Le constructeurs ne sont pas des méthodes comme les autres: le redéfinition na.
Généricité (fin) collections…. GénéricitéPOO-L3 H. Fauconnier2 Chapitre VII 1. Principes généraux 2. Types génériques imbriqués 3. Types paramètres bornés.
POO-L3 H. Fauconnier1 Tableau et héritage Y[] yA=new Y[3]; X[] xA=yA; //ok xA[0]=new Y(); xA[1]=new X(); //non xA[1]=new Z(); //non Object XX[]int[] YZY[]Z[]
Premier cours (23 septembre). Cours programmation- orientée objet en Java Licence dinformatique Hugues Fauconnier
Chapitre VII Généricité. POO-L3 H. Fauconnier2 Chapitre VII 1. Principes généraux 2. Types génériques imbriqués 3. Méthodes génériques 4. Types paramètres.
Chapitre III Héritage. POO-L3 H. Fauconnier2 Chapitre III: Héritage A) Extensions généralités Affectation et transtypage B) Méthodes Surcharge et signature.
Introduction au paradigme objet Concepts importants surcharge (overload) redéfinition (override) Définition d’une classe Définition des attributs.
Cours programmation-orientée objet en Java
77 Utilisation des classes (suite). 7-2 Objectifs A la fin de ce cours, vous serez capables de : Définir des méthodes surchargées dans une classe Fournir.
Langage Oriente Objet Cours 3.
Classes abstraites et Interfaces
Interfaces (fin) classes locales et internes, Object, clonage.
POO : Objets et classes (Rappels)
66 Utilisation des classes et des objets. 6-2 Objectifs A la fin de ce cours, vous serez capables de : Créer de nouvelles classes à laide de Eclipse Utiliser.
Introduction au paradigme orienté-objet (suite)
POO-L3 H. Fauconnier1 Supplément gratuit…. POO-L3 H. Fauconnier2 Entrée-sortie public static void main(String[] args) { // sortie avec printf ou double.
Design Pattern: Decorator
1 IFT 6800 Atelier en Technologies dinformation Le langage de programmation Java chapitre 3 : Classes et Objects.
Introduction Poo.
Cours du 22 novembre généricité. Chapitre VII Généricité.
Cours 6 Interfaces, classes imbriquées (début). Chapitre IV Interfaces, classes imbriquées, Object.
Chapitre III Héritage. POO-L3 H. Fauconnier2 Chapitre III: Héritage A) Extensions généralités Affectation et transtypage B) Méthodes Surcharge et signature.
Chapitre III Héritage. POO-L3 H. Fauconnier2 Chapitre III: Héritage A) Extensions généralités Affectation et transtypage B) Méthodes Surcharge et signature.
Cours 4 Héritage (suite).
Cours 11 Threads. Chapitre X threads threadPOO-L3 H. Fauconnier3 Threads threads: plusieurs activités qui coexistent et partagent des données exemples:
Cours2 Poo: rappels.
Cours 8 (18 novembre 2011) exceptions. héritagePOO-L3 H. Fauconnier2 Tableau et héritage Y[] yA=new Y[3]; X[] xA=yA; //ok xA[0]=new Y(); xA[1]=new X();
Cours 5 Héritage, Interfaces, classes internes. POO-L3 H. Fauconnier2 La classe Object Toutes les classes héritent de la classe Object Object méthodes:
COURS DE PROGRAMMATION ORIENTEE OBJET :
CSI1502 Principes fondamentaux en conception des logiciels
99 Réutilisation du code grâce à l'héritage. 9-2 Objectifs À la fin de ce cours, vous serez capables de : Définir l'héritage Utiliser l'héritage pour.
Héritage Licence Informatique Besançon Méthode et Outils pour la Programmation Françoise Greffier.
Cours 7 Divers et exceptions. Chapitre V Enumeration, tableaux, conversion de types, noms.
LIFI-Java 2004 Séance du Mercredi 22 sept. Cours 3.
Cours n°3 rappels. POO-L3 H. Fauconnier2 Entrée-sortie public static void main(String[] args) { // sortie avec printf ou double a = 5.6d ; double b =
La notion de type revisitée en POO
Cours du 3/12. Threads threadPOO-L3 H. Fauconnier3 Threads  threads: plusieurs activités qui coexistent et partagent des données exemples:  pendant.
Cours 9 Exceptions (fin) Généricité. POO-L3 H. Fauconnier2 Chaînage d'exceptions  Une exception peut être causée par une autre.  il peut être utile.
11/04/ L'héritage Cours 7 Cours 7.
Cours 7 Classes locales Clonage Divers: tableaux.
Tutorat en bio-informatique
Les classes présenté par: RAHMOUNE RIME / ZEKRI SELMA.
Les classes et les objets Les données finales class A { … private final int n = 20 ; // la valeur de n est définie dans sa déclaration … } class A { public.
Schéma de conception Factory Method Exemple Sylvain Giroux.
Cours du 5 novembre.
Héritage H. Batatia. plan Notion (que signifie l’héritage) Ecriture en java Héritage multiple (interdit) Instanciation (partie propre et partie héritée)
Cours 4 (14 octobre) Héritage. Chapitre III Héritage.
Introduction à la programmation objet avec java
Héritage Conception par Objet et programmation Java
Cours du 26 octobre  Classes internes  Clones POO-L3 H. Fauconnier1.
Cours 3 Héritage (début). classes et objetsPOO-L3 H. Fauconnier2 Passage par valeur public class ParamParVal { public static void parVal(int i){ i=0;
E) Constructeurs et héritage
Transcription de la présentation:

POO-L3 H. Fauconnier1 C) Méthodes: Redéfinition Un classe hérite des méthodes des classes ancêtres Elle peut ajouter de nouvelles méthodes Elle peut surcharger des méthodes Elle peut aussi redéfinir des méthodes des ancêtres.

POO-L3 H. Fauconnier2 Exemple class Mere{ void f(int i){ System.out.println("f("+i+") de Mere"); } void f(String st){ System.out.println("f("+st+") de Mere"); }

POO-L3 H. Fauconnier3 Exemple (suite) class Fille extends Mere{ void f(){ //surcharge System.out.println("f() de Fille"); } // char f(int i){ // même signature mais type de retour différent // } void g(){ //nouvelle méthode System.out.println("g() de Fille"); f(); f(3); f("bonjour"); } void f(int i){ // redéfinition System.out.println("f("+i+") de Fille"); }

POO-L3 H. Fauconnier4 Exemple public static void main(String[] args) { Mere m=new Mere(); Fille f=new Fille(); m.f(3); f.f(4); m=f; m.f(5); //m.g(); ((Fille)m).g(); f.g(); }

POO-L3 H. Fauconnier5 Résultat f(3) de Mere f(4) de Fille f(5) de Fille g() de Fille f() de Fille f(3) de Fille f(bonjour) de Mere g() de Fille f() de Fille f(3) de Fille f(bonjour) de Mere

POO-L3 H. Fauconnier6 D) Conséquences Et les variables? Principe: Une méthode (re)définie dans une classe A ne peut être évaluée que dans le contexte des variables définies dans la classe A.

POO-L3 H. Fauconnier7 Exemple class A{ public int i=4; public void f(){ System.out.println("f() de A, i="+i); } public void g(){ System.out.println("g() de A, i="+i); } class B extends A{ public int i=3; public void f(){ System.out.println("f() de B, i="+i); g(); }

POO-L3 H. Fauconnier8 Exemple suite: A a=new B(); a.f(); System.out.println("a.i="+a.i); System.out.println("((B) a).i="+((B)a).i); Donnera: f() de B, i=3 g() de A, i=4 a.i=4 ((B) a).i=3

POO-L3 H. Fauconnier9 Remarques: La variable i de A est occultée par la variable i de B La variable i de A est toujours présente dans tout objet de B Le méthode g de A a accès à toutes les variables définies dans A (et uniquement à celles-là) La méthode f de B redéfinit f. f() redéfinie a accès à toutes les variables définies dans B

POO-L3 H. Fauconnier10 E) Divers super Le mot clé super permet daccéder aux méthodes de la super classe En particulier super permet dans une méthode redéfinie dappeler la méthode dorigine (exemple: super.finalize() appelé dans une méthode qui redéfinit le finalize permet d'appeler le finalize de la classe de base)

POO-L3 H. Fauconnier11 Exemple class Base{ protected String nom(){ return "Base"; } class Derive extends Base{ protected String nom(){ return "Derive"; } protected void print(){ Base maref = (Base) this; System.out.println("this.name():"+this.nom()); System.out.println("maref.name():"+maref.nom()); System.out.println("super.name():"+super.nom()); } this.name():Derive maref.name():Derive super.name():Base

POO-L3 H. Fauconnier12 Contrôle daccès protected : accès dans les classes dérivées Le contrôle daccès ne concerne pas la signature Une méthode redéfinie peut changer le contrôle daccès mais uniquement pour élargir laccès (de protected à public ) Le contrôle daccès se fait à la compilation

POO-L3 H. Fauconnier13 Interdire la redéfinition Le modificateur final interdit la redéfinition pour une méthode (Bien sûr une méthode de classe ne peut être redéfinie! Elle peut être surchargée) Une variable avec modificateur final peut être occultée

POO-L3 H. Fauconnier14 E) Constructeurs et héritage Le constructeurs ne sont pas des méthodes comme les autres: le redéfinition na pas de sens. Appeler un constructeur dans un constructeur super() appelle le constructeur de la super classe this() appelle le constructeur de la classe elle- même Ces appels doivent se faire au début du code du constructeur

POO-L3 H. Fauconnier15 Constructeurs Principe: Quand une méthode dinstance est appelée lobjet est déjà créé. Création de lobjet (récursivement) 1. Invocation du constructeur de la super classe 2. Initialisations des champs par les initialisateurs et les blocs dinitialisation 3. Une fois toutes ces initialisations faites appel du corps du constructeur (super() et this() ne font pas partie du corps)

POO-L3 H. Fauconnier16 Exemple class X{ protected int xMask=0x00ff; protected int fullMask; public X(){ fullMask = xMask; } public int mask(int orig){ return (orig & fullMask); } class Y extends X{ protected int yMask = 0xff00; public Y(){ fullMask |= yMask; }

POO-L3 H. Fauconnier17 Résultat xMaskyMaskfullMask Val. par défaut des champs000 Appel Constructeur pour Y000 Appel Constructeur pour X000 Initialisation champ X0x00ff00 Constructeur X0x00FF0 Initialisation champs de Y0x00FF0xFF000x00FF Constructeur Y0x00FF0xFF000xFFFF

POO-L3 H. Fauconnier18 Remarques: on ne peut pas (bien sûr) redéfinir une méthode statique le modificateur final permet d'empêcher la redéfinition d'une classe

POO-L3 H. Fauconnier19 La classe Objet Toutes les classes héritent de la classe Object Object méthodes: public final Class getClass()ClassObject public int hashCode() public boolean equals(Object obj)Object protected Object clone() throws CloneNotSupportedExceptionObject CloneNotSupportedException public String toString()String protected void finalize() throws ThrowableThrowable (wait, notify,notfyall)

POO-L3 H. Fauconnier20 Exemple class A{ int i; int j; A(int i,int j){ this.i=i;this.j=j;} } class D { T i; D(T i){ this.i=i; }

POO-L3 H. Fauconnier21 Suite public static void main(String[] args) { A a=new A(1,2); A b=new A(1,2); A c=a; if (a==b) System.out.println("a==b"); else System.out.println("a!=b"); if (a.equals(b)) System.out.println("a equals b"); else System.out.println("a not equals b"); System.out.println("Objet a: "+a.toString()+" classe "+a.getClass()); System.out.println("a.hashCode()"+a.hashCode()); System.out.println("b.hashCode()"+b.hashCode()); System.out.println("c.hashCode()"+c.hashCode()); D x=new D (10); System.out.println("Objet x: "+x.toString()+" classe "+x.getClass()); }

POO-L3 H. Fauconnier22 Résultat: a!=b a not equals b Objet a: classe class A a.hashCode() b.hashCode() c.hashCode() Objet x: classe class D

POO-L3 H. Fauconnier23 En redéfinissant equals class B{ int i; int j; B(int i,int j){ this.i=i;this.j=j; } public boolean equals(Object o){ if (o instanceof B) return i==((B)o).i && j==((B)o).j; else return false; }

POO-L3 H. Fauconnier24 Suite B d=new B(1,2); B e=new B(1,2); B f=e; if (d==e) System.out.println("e==d"); else System.out.println("d!=e"); if (d.equals(e)) System.out.println("d equals e"); else System.out.println("a not equals b"); System.out.println("Objet d: "+d.toString()); System.out.println("Objet e: "+e.toString()); System.out.println("d.hashCode()"+d.hashCode()); System.out.println("e.hashCode()"+e.hashCode());

POO-L3 H. Fauconnier25 Résultat: d!=e d equals e Objet d: Objet e: d.hashCode() e.hashCode()

Chapitre IV Object, interfaces, classes imbriquées

POO-L3 H. Fauconnier27 Chapitre IV 1. classe Object, clonage 2. interfaces 3. classes imbriquées

POO-L3 H. Fauconnier28 Le clonage les variables sont des références sur des objets -> l'affectation ne modifie pas l'objet la méthode clone retourne un nouvel objet dont la valeur initiale est une copie de l'objet

POO-L3 H. Fauconnier29 Points techniques Par défaut la méthode clone duplique les champs la méthode clone de Object lance une exception CloneNotSupportedException l'interface Cloneable doit être implémentée pour pouvoir utiliser la méthode clone la méthode clone est protected -> elle ne peut être utilisée quand dans les méthodes définies dans la classe ou ses descendantes.

POO-L3 H. Fauconnier30 En conséquence en implémentant Cloneable, le clonage est possible pour la classe et les descendants directement en implémentant Cloneable et en laissant passer l'exception CloneNotSupportedException, le clonage est possible en n'implémentant pas Cloneable et en définissant une méthode clone qui jette CloneNotSupportedException, le clonage n'est plus possible si Cloneable n'est pas implémenté CloneNotSupportedException est lancée à chaque appel de clone

POO-L3 H. Fauconnier31 Exemple class A implements Cloneable{ int i,j; A(int i,int j){ this.i=i; this.j=j; } public String toString(){ return "(i="+i+",j="+j+")"; } protected Object clone() throws CloneNotSupportedException{ return super.clone(); }

POO-L3 H. Fauconnier32 Suite A a1=new A(1,2); A a2=null; try {// nécessaire! a2 =(A) a1.clone(); } catch (CloneNotSupportedException ex) { ex.printStackTrace(); } donnera: a1=(i=1,j=2) a2=(i=1,j=2)

POO-L3 H. Fauconnier33 Suite class D extends A{ int k; D(int i,int j){ super(i,j); k=0; } public String toString(){ return ("(k="+k+")"+super.toString()); } //… D d1=new D(1,2); D d2=null; try { //nécessaire d2=(D) d1.clone(); } catch (CloneNotSupportedException ex) { ex.printStackTrace(); } System.out.println("d1="+d1+" d2="+d2); }

POO-L3 H. Fauconnier34 Suite class B implements Cloneable{ int i,j; B(int i,int j){ this.i=i; this.j=j; } public String toString(){ return "(i="+i+",j="+j+")"; } protected Object clone(){ try { return super.clone(); } catch (CloneNotSupportedException ex) { ex.printStackTrace(); return null; }

POO-L3 H. Fauconnier35 Suite class C extends B{ int k; C(int i,int j){ super(i,j); k=0; } public String toString(){ return ("(k="+k+")"+super.toString()); } }//... B b1=new B(1,2); B b2 =(B) b1.clone(); C c1=new C(1,2); C c2 =(C) c1.clone();

POO-L3 H. Fauconnier36 Pourquoi le clonage? Partager ou copier? Copie profonde ou superficielle? par défaut la copie est superficielle:

POO-L3 H. Fauconnier37 Exemple class IntegerStack implements Cloneable{ private int[] buffer; private int sommet; public IntegerStack(int max){ buffer=new int[max]; sommet=-1; } public void empiler(int v){ buffer[++sommet]=v; } public int dépiler(){ return buffer[sommet--]; } public IntegerStack clone(){ try{ return (IntegerStack)super.clone(); }catch(CloneNotSupportedException e){ throw new InternalError(e.toString()); }

POO-L3 H. Fauconnier38 Problème: IntegerStack un=new IntegerStack(10); un.emplier(3); un.empiler(9) InetegerStack deux=un.clone(); Les deux piles partagent les mêmes données…

POO-L3 H. Fauconnier39 Solution… public IntegerStack clone(){ try{ IntegerStack nObj = (IntegerStack)super.clone(); nObj.buffer=buffer.clone(); return nObj; }catch(CloneNotSupportedException e){ //impossible throw new InternalError(e.toString()); }

POO-L3 H. Fauconnier40 Copie profonde public class CopieProfonde implements Cloneable{ int val; CopieProfonde n=null; /** Creates a new instance of CopieProfonde */ public CopieProfonde(int i) { val=i; } public CopieProfonde(int i, CopieProfonde n){ this.val=i; this.n=n; } public Object clone(){ CopieProfonde tmp=null; try{ tmp=(CopieProfonde)super.clone(); if(tmp.n!=null) tmp.n=(CopieProfonde)(tmp.n).clone(); }catch(CloneNotSupportedException ex){} return tmp; }

POO-L3 H. Fauconnier41 Suite class essai{ static void affiche(CopieProfonde l){ while(l!=null){ System.out.println(l.val+" "); l=l.n; } public static void main(String[] st){ CopieProfonde l=new CopieProfonde(0); CopieProfonde tmp; for(int i=0;i<10;i++){ tmp=new CopieProfonde(i,l); l=tmp; } affiche(l); CopieProfonde n=(CopieProfonde)l.clone(); affiche(n); }