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.

Slides:



Advertisements
Présentations similaires
PHP5 its a kind of magic. Chargement automatique function __autoload( $nom_classe ) { require_once('obj/'.$nom_classe.'.class.php'); } si on exécute le.
Advertisements

Spécialisation/généralisation Héritage Polymorphisme
Introspection et Réflexion Manipulation dynamique de code Java.
Arbres Un premier exemple Contenu Rendu Ecouteurs Parcours
Les entrées /sorties en Java François Bonneville
Chapitre IV Object, interfaces, classes imbriquées.
Chapitre III Héritage (début)
VI) exemple: Les astres…
BlueJ_XI 1 Java, les objets : tout de suite ! Gestion des erreurs : les exceptions Notes de cours associées au chapitre 11 tutorial BlueJ
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
POO-L3 H. Fauconnier1 Chapitre IV 1. classe Object, clonage 2. interfaces 3. classes internes et imbriquées.
Faculté I&C, Claude Petitpierre, André Maurer 1 Java.
Langage Oriente Objet Cours 4.
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.
Badr Benmammar Programmation concurrente et temps réel en Java Badr Benmammar
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.
Master 1 SIGLIS java Lecteur Stéphane Tallard Chapitre 4 – Structures de contrôle.
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.
Classes abstraites et Interfaces
Interfaces (fin) classes locales et internes, Object, clonage.
Historique de SystemC Regroupe 4 courants didées: SCENIC Project : Synopsys+UC Irvine Philips System-Level Data Types, VSIA SLD DWG IMEC, Hardware-Software.
Le patron de conception « Strategy » Simon Durocher ( )
Programmation par Objets et Java
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 à la Programmation Orientée Objet Retour sur les principaux concepts SI3 MAM3 Hydro Nathan Cohen
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
Faculté I&C, Claude Petitpierre, André Maurer 1 Concepts dhéritage Héritage dimplémentation hasA Héritage de spécialisation isA.
Multi-Thread Jian-Yun Nie
1 Les paquetages («packages»). 2 L'objectif avec les paquetages («packages») est de rendre accessibles aux utilisateurs des classes définies par d'autres.
1 IFT 6800 Atelier en Technologies dinformation Le langage de programmation Java chapitre 3 : Classes et Objects.
Badr Benmammar Programmation concurrente et temps réel en Java Badr Benmammar
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 :
CSI 1502 Principes fondamentaux de conception de 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.
Cours 7 Divers et exceptions. Chapitre V Enumeration, tableaux, conversion de types, noms.
Objectifs À la fin de ce cours, vous serez capables de :
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 =
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
Constructeurs H Batatia. Variable statique Une variable statique est partagée par tous les objets d’une classe.
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.
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 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:

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 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. Fauconnier3 Constructeurs Principes: 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. Fauconnier4 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. Fauconnier5 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. Fauconnier6 La classe Object 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. Fauconnier7 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. Fauconnier8 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. Fauconnier9 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. Fauconnier10 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. Fauconnier11 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. Fauconnier12 Résultat: d!=e d equals e Objet d: Objet e: d.hashCode() e.hashCode()

Chapitre IV Interfaces, classes imbriquées, Object

POO-L3 H. Fauconnier14 Chapitre IV 1. Interfaces 2. Classes imbriquées 3. Objets, clonage

POO-L3 H. Fauconnier15 classes abstraites abstract class Benchmark{ abstract void benchmark(); public final long repeat(int c){ long start =System.nanoTime(); for(int i=0;i<c;i++) benchmark(); return (System.nanoTime() -start); } class MonBenchmark extends Benchmark{ void benchmark(){ } public static long mesurer(int i){ return new MonBenchmark().repeat(i); }

POO-L3 H. Fauconnier16 suite public static void main(String[] st){ System.out.println("temps="+ MonBenchmark.mesurer( )); } Résultat: temps=

POO-L3 H. Fauconnier17 Interfaces Il n'y a pas d'héritage multiple en Java: une classe ne peut être l'extension que d'une seule classe Par contre une classe peut implémenter plusieurs interfaces (et être l'extension d'une seule classe) Une interface ne contient (essentiellement) que des déclarations de méthodes Une interface est un peu comme une classe sans données membres et dont toutes les méthodes seraient abstraites

POO-L3 H. Fauconnier18 Héritage "multiple" en java

POO-L3 H. Fauconnier19 Exemple: interface Comparable { int compareTo(T obj); } class Couple implements Comparable { int x,y; // public int compareTo(Couple c){ if(x<c.x)return 1; else if (c.x==x) if (c.y==y)return 0; return -1; }

POO-L3 H. Fauconnier20 Remarques… Pourquoi, a priori, l'héritage multiple est plus difficile à implémenter que l'héritage simple? Pourquoi, a priori, implémenter plusieurs interfaces ne pose pas (trop) de problèmes? (Comment ferait-on dans un langage comme le C?)

POO-L3 H. Fauconnier21 Quelques interfaces… Cloneable : est une interface vide(!) un objet qui l'implémente peut redéfinir la méthode clone Comparable : est une interface qui permet de comparer les éléments (méthode compareTo ) runnable : permet de définir des "threads" Serializable : un objet qui l'implémente peut être "sérialisé" = converti en une suite d'octets pour être sauvegarder.

POO-L3 H. Fauconnier22 Déclarations une interface peut déclarer: des constantes (toutes les variables déclarées sont static public et final ) des méthodes (elles sont implicitement abstract ) des classes internes et des interfaces

POO-L3 H. Fauconnier23 Extension les interfaces peuvent être étendues avec extends: Exemple: public interface SerializableRunnable extends Serializable, Runnable; (ainsi une interface peut étendre de plusieurs façons une même interface, mais comme il n'y a pas d'implémentation de méthodes et uniquement des constantes ce n'est pas un problème)

POO-L3 H. Fauconnier24 Exemple interface X{ int val=0; } interface Y extends X{ int val=1; int somme=val+X.val; } class Z implements Y{} public class InterfaceHeritage { public static void main(String[] st){ System.out.println("Z.val="+Z.val+" Z.somme="+Z.somme); Z z=new Z(); System.out.println("z.val="+z.val+ " ((Y)z).val="+((Y)z).val+ " ((X)z).val="+((X)z).val); } Z.val=1 Z.somme=1 z.val=1 ((Y)z).val=1 ((X)z).val=0

POO-L3 H. Fauconnier25 Redéfinition, surcharge interface A{ void f(); void g(); } interface B{ void f(); void f(int i); void h(); } interface C extends A,B{} Rien n'indique que les deux méthodes void f() ont la même "sémantique". Comment remplir le double contrat?

POO-L3 H. Fauconnier26 Chapitre IV 1. Interfaces 2. Classes internes et imbriquées 3. Object, clonage

POO-L3 H. Fauconnier27 Classes imbriquées (nested classes) Classes membres statiques membres statiques d'une autre classe Classes membres ou classes internes (inner classes) membres d'une classe englobante Classes locales classes définies dans un bloc de code Classes anonymes classes locales sans nom

POO-L3 H. Fauconnier28 Classe imbriquée statique membre statique d'une autre classe classe ou interface mot clé static similaire aux champs ou méthodes statiques: n'est pas associée à une instance et accès uniquement aux champs statiques

POO-L3 H. Fauconnier29 Exemple class PileChainee{ public static interface Chainable{ public Chainable getSuivant(); public void setSuivant(Chainable noeud); } Chainable tete; public void empiler(Chainable n){ n.setSuivant(tete); tete=n; } public Object depiler(){ Chainable tmp; if (!estVide()){ tmp=tete; tete=tete.getSuivant(); return tmp; } else return null; } public boolean estVide(){ return tete==null; }

POO-L3 H. Fauconnier30 exemple (suite) class EntierChainable implements PileChainee.Chainable{ int i; public EntierChainable(int i){this.i=i;} PileChainee.Chainable next; public PileChainee.Chainable getSuivant(){ return next; } public void setSuivant(PileChainee.Chainable n){ next=n; } public int val(){return i;} }

POO-L3 H. Fauconnier31 et le mainmain public static void main(String[] args) { PileChainee p; EntierChainable n; p=new PileChainee(); for(int i=0; i<12;i++){ n=new EntierChainable(i); p.empiler(n); } while (!p.estVide()){ System.out.println( ((EntierChainable)p.depiler()).val()); }

POO-L3 H. Fauconnier32 Remarques Noter l'usage du nom hiérarchique avec '.' On peut utiliser un import: import PileChainee.Chainable; import PileChainee; (Exercice: réécrire le programme précédent sans utiliser de classes membres statiques)

POO-L3 H. Fauconnier33 Classe membre membre non statique d'une classe englobante peut accéder aux champs et méthodes de l'instance une classe interne ne peut pas avoir de membres statiques un objet d'une classe interne est une partie d'un objet de la classe englobante

POO-L3 H. Fauconnier34 Exemple class CompteBanquaire{ private long numero; private long balance; private Action der; public class Action{ private String act; private long montant; Action(String act, long montant){ this.act=act; this.montant= montant; } public String toString(){ return numero"+":"+act+" "+montant; }

POO-L3 H. Fauconnier35 Suite //… public void depot(long montant){ balance += montant; der=new Action("depot",montant); } public void retrait(long montant){ balance -= montant; der=new Action("retrait",montant); } }

POO-L3 H. Fauconnier36 Remarques numero dans toString this: der=this.new Action(…); CompteBancaire.this.numero

POO-L3 H. Fauconnier37 Classe interne et héritage class Externe{ class Interne{} } class ExterneEtendue extends Externe{ class InterneEtendue extends Interne{} Interne r=new InterneEtendue(); } class Autre extends Externe.Interne{ Autre(Externe r){ r.super(); } (un objet Interne (ou d'une de ses extensions) n'a de sens qu'à l'intérieur d'un objet Externe)

POO-L3 H. Fauconnier38 Quelques petits problèmes class X{ int i; class H extends Y{ void incremente(){i++;} } Si i est une donnée membre de Y… c'est ce i qui est incrémenté X.this.i et this.i lèvent cette ambiguïté.

POO-L3 H. Fauconnier39 Suite class H{ void print(){} void print(int i){} class I{ void print(){}; void show(){ print(); H.this.print(); // print(1); tous les print sont occultés }