Cours 6 Interfaces, classes imbriquées (début). Chapitre IV Interfaces, classes imbriquées, Object.

Slides:



Advertisements
Présentations similaires
POO par Jenny Benois-Pineau 25/03/2017.
Advertisements

1 Tableaux des objets C++ si on connaît le nombre dobjets nécessaires davance on peut utiliser des tableau dobjets dans les fonctions dusage class Personne.
POO.
la programmation en langage C
Programmer en JAVA par Tama
Exercice 1 1 (père) et 1 (fils) 1 (père) et 0 (fils)
Les fonctions en Java Partie I Le type void. Dans cette rapide présentation, je vais expliquer :.à quoi servent les fonctions.à quoi faut-il penser avant.
Introduction à la POO: Les classes vs les objets
CYCLE 6 : FONCTIONS FONCTIONS avec paramètres en Entrée 1- Pourquoi les FONCTIONS peuvent échanger des données en E entre elles ? 2- Comment écrire des.
Chapitre IV Object, interfaces, classes imbriquées.
Chapitre III Héritage (début)
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.
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.
COURS DE PROGRAMMATION ORIENTEE OBJET :
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
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.
IFT1025, Programmation 2 Jian-Yun Nie
Classes abstraites et Interfaces
Interfaces (fin) classes locales et internes, Object, clonage.
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 Patterns Factory Method – Pattern de construction [DANT] Génie Logiciel 1.
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.
Langages orientés objets
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é.
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:
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
Structures de données IFT-2000 Abder Alikacem L’héritage en C++ Département d’informatique et de génie logiciel Édition Septembre 2009.
Cours 7 Divers et exceptions. Chapitre V Enumeration, tableaux, conversion de types, noms.
Chapitre IX Gestion de flux.
AP4 - Programmation Orientée Objet Chapitre 3 : Programmation Objet en C++ class Entier { int i; int lit_i(void); void Ecrit_i(int); }; int Entier::lit_i(void)
Objectifs À la fin de ce cours, vous serez capables de :
Les collections. Gestion d’ensembles d’objets Tableaux Taille fixe Pas de manipulation aisée des objets dans le tableaux Base tab1[]= new Base[5]; for(int.
LIFI-Java 2004 Séance du Mercredi 22 sept. Cours 3.
Copyright © SUPINFO. All rights reserved La Programmation Orientée Objet en C# 2.0.
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 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.
Cours 7 Classes locales Clonage Divers: tableaux.
Constructeurs H Batatia. Variable statique Une variable statique est partagée par tous les objets d’une classe.
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.
Chapitre VII Techniques plus avancées à travers le concept de classe.
LIFI-Java 2004 Séance du Mercredi 29 sept. Cours 4.
Introduction à la programmation objet avec java
Classes abstraites, interface Classe interne Classes enveloppes
Les objets de la classe de classe. Qu'est-ce que c'est? C'est...
BlueJ_VII 1 Java, les objets : tout de suite ! Conception de classes (1) Notes de cours associées au chapitre 7 tutorial BlueJ
Programmation orientée objet AppInventor ArduBlock Communication
                                           .
E) Constructeurs et héritage
Int 10. Int 6.
TP N°6: Construction d’un Serveur Multi-Client
Transcription de la présentation:

Cours 6 Interfaces, classes imbriquées (début)

Chapitre IV Interfaces, classes imbriquées, Object

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

POO-L3 H. Fauconnier4 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. Fauconnier5 suite public static void main(String[] st){ System.out.println("temps="+ MonBenchmark.mesurer( )); } Résultat: temps=

POO-L3 H. Fauconnier6 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. Fauconnier7 Héritage "multiple" en java

POO-L3 H. Fauconnier8 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. Fauconnier9 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. Fauconnier10 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. Fauconnier11 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. Fauconnier12 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. Fauconnier13 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. Fauconnier14 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. Fauconnier15 Chapitre IV 1. Interfaces 2. Classes internes et imbriquées 3. Object, clonage

POO-L3 H. Fauconnier16 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. Fauconnier17 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. Fauconnier18 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. Fauconnier19 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. Fauconnier20 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. Fauconnier21 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. Fauconnier22 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. Fauconnier23 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. Fauconnier24 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. Fauconnier25 Remarques numero dans toString this: der=this.new Action(…); CompteBancaire.this.numero

POO-L3 H. Fauconnier26 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. Fauconnier27 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. Fauconnier28 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 }

POO-L3 H. Fauconnier29 Classes locales classes définies à l'intérieur d'un bloc de code, analogue à des variables locales: une classe interne locale n'est pas membre de la classe et donc pas d'accès, usage: créer des instances qui peuvent être passées en paramètres usage: créer des objets d'une extension d'une classe qui n'a de sens que localement (en particulier dans les interfaces graphiques)

POO-L3 H. Fauconnier30 Exemple classes Collections (ou Containers): classes correspondant à des structures de données. exemples: List, Set, Queue, Map. L'interface Iterator permet de parcourir tous les éléments composant une structure de données.

POO-L3 H. Fauconnier31 Iterator public interface Iterator { boolean hasNext(); E next() throws NoSuchElementException; void remove()throws UnsupportedOperationException, IllegalStateException; }

POO-L3 H. Fauconnier32 Exemple: MaCollectionMaCollection class MaCollection implements Iterator { Object[] data; MaCollection(int i){ data=new Object[i]; } MaCollection(Object... l){ data=new Object[l.length]; for(int i=0;i<l.length;i++) data[i]=l[i]; } private int pos=0; public boolean hasNext(){ return (pos <data.length); } public Object next() throws NoSuchElementException{ if (pos >= data.length) throw new NoSuchElementException(); return data[pos++]; } public void remove(){ throw new UnsupportedOperationException(); }

POO-L3 H. Fauconnier33 Et une iteration:iteration public class Main { public static void afficher(Iterator it){ while(it.hasNext()){ System.out.println(it.next()); } public static void main(String[] args) { MaCollection m=new MaCollection(1,2,3,5,6,7); afficher(m); }

POO-L3 H. Fauconnier34 Classe locale Au lieu de créer d'implémenter Iterator on pourrait aussi créer une méthode qui retourne un iterateur.

POO-L3 H. Fauconnier35 Exemple parcourirparcourir public static Iterator parcourir(final Object[] data){ class Iter implements Iterator { private int pos=0; public boolean hasNext(){ return (pos <data.length); } public Object next() throws NoSuchElementException{ if (pos >= data.length) throw new NoSuchElementException(); return data[pos++]; } public void remove(){ throw new UnsupportedOperationException(); } return new Iter(); }

POO-L3 H. Fauconnier36 et l'appel Integer[] tab=new Integer[12]; //… afficher(parcourir(tab));