Introduction au langage de programmation Java



Documents pareils
Une introduction à Java

Programmer en JAVA. par Tama

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

as Architecture des Systèmes d Information

Introduction à Java. Matthieu Herrb CNRS-LAAS. Mars

TP1 : Initiation à Java et Eclipse

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

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

Initiation à JAVA et à la programmation objet.

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

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

Plan du cours. Historique du langage Nouveautés de Java 7

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

Java 1.5 : principales nouveautés

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

INITIATION AU LANGAGE JAVA

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

Cours 1: Java et les objets

Chapitre VI- La validation de la composition.

PROGRAMMATION PAR OBJETS

Java c est quoi? Java pourquoi?

Aide mémoire UML & Java 1ère partie : Introduction. marc.lemaire@u-cergy.fr

Info0101 Intro. à l'algorithmique et à la programmation. Cours 3. Le langage Java

Cours 1 : Introduction. Langages objets. but du module. contrôle des connaissances. Pourquoi Java? présentation du module. Présentation de Java

JAVA. Introduction à la programmation objet avec java 1/4. Nadir BOUSSOUKAIA

Programmation Par Objets

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

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

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

Premiers Pas en Programmation Objet : les Classes et les Objets

Polycopié Cours Programmation Orientée Objet sous Java Programme : Filière SMI S5

RN2-Programmation Orientée Objet - JAVA CH 1 Introduction à la POO et Java

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

Java Licence Professionnelle CISII,

Java Licence Professionnelle CISII,

INTRODUCTION A JAVA. Fichier en langage machine Exécutable

Java c est quoi? Java. Java. Java : Principe de fonctionnement 31/01/ Vue générale 2 - Mon premier programme 3 - Types de Programme Java

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

Package Java.util Classe générique

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

Java Licence Professionnelle CISII, Cours 2 : Classes et Objets

Langage Java. Classe de première SI

Auto-évaluation Programmation en Java

RMI le langage Java XII-1 JMF

Utilisation d objets : String et ArrayList

Java Licence professionnelle CISII,

La technologie Java Card TM

Chapitre 10. Les interfaces Comparable et Comparator 1

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

Bases du langage. Historique Applications et applets Éléments de base du langage Classes et objets Les exceptions

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

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

Remote Method Invocation (RMI)

Bases Java - Eclipse / Netbeans

La carte à puce. Jean-Philippe Babau

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

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

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

TD/TP PAC - Programmation n 3

Programmation Objet Java Correction

Programmation par les Objets en Java

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

Cours 1 : La compilation

Initiation à la programmation orientée-objet avec le langage Java

Java - la plateforme

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

Traduction des Langages : Le Compilateur Micro Java

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

Étude de l interopérabilité de deux langages de programmation basée sur la machine virtuelle de Java

TD/TP PAC - Programmation n 3

Environnements de développement (intégrés)

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

Lambda! Rémi Forax Univ Paris-Est Marne-la-Vallée

Threads. Threads. USTL routier 1

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

Introduction : les processus. Introduction : les threads. Plan

ALGORITHMIQUE ET PROGRAMMATION ORIENTEE OBJET

La JVM. La machine virtuelle Java. La JVM. La JVM

Programmation Orientée Objet Java

Introduction. Les méthodes. Les méthodes. Identité et égalité. Identité et égalité. La copie d'objets. Identité et égalité.

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

TP, première séquence d exercices.

Chapitre I Notions de base et outils de travail

Introduction au langage Java

Programmation Orientée Objets Le Langage JAVA

Remote Method Invocation Les classes implémentant Serializable

Introduction au langage C

Quelques patterns pour la persistance des objets avec DAO DAO. Principe de base. Utilité des DTOs. Le modèle de conception DTO (Data Transfer Object)

Programmation en Java IUT GEII (MC-II1) 1

NFP 121. Java et les Threads. Présentation : Thierry Escalarasse Mai 2007

Apprendre Java en 154 minutes

Un ordonnanceur stupide

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

Annexe : La Programmation Informatique

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

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

TP1. Outils Java Eléments de correction

Java et les bases de données: JDBC: Java DataBase Connectivity SQLJ: Embedded SQL in Java. Michel Bonjour

Classe Interne, Anonyme & Enumération

INF 321 : mémento de la syntaxe de Java

Transcription:

Introduction au langage de programmation Java Christian Bac, Denis Conan CSC 4002 Octobre 2014 Revision : 996

Introduction au langage de programmation Java Sommaire du cours 1 Introduction à Java............................................................. 3 2 Concepts de bases de Java..................................................... 22 3 Classes et objets en Java....................................................... 36 4 Généralisation spécialisation en Java............................................ 58 5 Organisation des sources Java.................................................. 83 6 API Java...................................................................... 95 7 Exceptions en Java........................................................... 130 8 Concepts objets avancés en Java...............................................143 Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 2/169

Introduction au langage de programmation Java 1 Introduction à Java 1.1 Vous avez dit Java?........................................................... 4 1.2 Que recouvre le mot Java?.................................................... 9 1.3 Caractéristiques.............................................................. 12 1.4 Historique de l API........................................................... 16 1.5 Environnements de développement............................................ 17 1.6 En savoir plus................................................................ 19 Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 3/169

Introduction au langage de programmation Java 1.1 Vous avez dit Java? 1 Introduction à Java À quoi cela sert-il? Pourquoi nous? Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 4/169

1 Introduction à Java 1.1 Vous avez dit Java? 1.1.1 Android Android : Java est le logiciel prépondérant des + 500 000 applications. Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 5/169

1 Introduction à Java 1.1 Vous avez dit Java? 1.1.2 CAS Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 6/169

1 Introduction à Java 1.1 Vous avez dit Java? 1.1.3 Java partout! Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 7/169

1 Introduction à Java 1.1 Vous avez dit Java? 1.1.4 Pourquoi nous? Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 8/169

Introduction au langage de programmation Java 1.2 Que recouvre le mot Java? 1 Introduction à Java Un projet et des évolutions sur + de 20 ans Un langage objet Une architecture basée sur une machine virtuelle Des interfaces de programmation objet Des outils (Java Development Kit) Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 9/169

1 Introduction à Java 1.2 Que recouvre le mot Java? 1.2.1 Héros Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 10/169

1 Introduction à Java 1.2 Que recouvre le mot Java? 1.2.2 Projet et Historique 1990 : équipe autour de James Gosling et sous l impulsion de Bill Joy 1993 : projet de langage pour l électronique grand public 1995 : Java Development Kit (JDK) 1.0 b1 + support dans le navigateur Netscape 1998 : mise en place du Java Community Process 1999 : Java 2 Standard Edition (J2SE) 1.2 (Java DataBase Connector amélioré, interface graphique Swing, collections) 2005 : J2SE 1.5, alors renommé J2SE 5 (types paramétrés, annotations, collections revues) 2006-2007 : J2SE6 et libération du code passage sous licence General Public License, alias GNU/GPL 2009 : rachat de SUN microsystems par ORACLE 2011 : J2SE 7 Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 11/169

Introduction au langage de programmation Java 1.3 Caractéristiques 1 Introduction à Java Objet Exécuté par une machine virtuelle Permettant d écrire des programmes robustes Simple : C comme syntaxe de base Sûr, multi-activité, réparti Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 12/169

1 Introduction à Java 1.3 Caractéristiques 1.3.1 Java un langage Objet Tout est classe sauf les types primitifs (int, float, double, etc.) Tout objet est manipulé à travers une référence La spécialisation est simple entre les classes Toutes les classes dérivent de java.lang.object Les tableaux sont construits à partir d une classe particulière L API (en anglais, Application Programming Interface) est un ensemble de classes Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 13/169

1 Introduction à Java 1.3 Caractéristiques 1.3.2 Machine Virtuelle Java Les compilateurs génèrent du code intermédiaire (en anglais, bytecode) Ce code intermédiaire est interprété par les «Java Virtual Machines» (JVM) Modèle «compile once execute everywhere» Java Virtual Machine (JVM) : s exécutent sur les systèmes d exploitation (par exemple avec la commande java) ou sont intégrées dans les navigateurs Web Sémantique du langage plus stricte que celle du langage C Taille et domaine de valeur des types primitifs identiques sur toutes les plate-formes Code source Unicode (accents et autres glyphes) Bibliothèques standards riches Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 14/169

1 Introduction à Java 1.3 Caractéristiques 1.3.3 Robustesse Conçu pour du logiciel embarqué Gestion de la mémoire avec ramasse miettes (en anglais, garbage collector) Pas d accès à la mémoire physique Gestion des erreurs par exception (voir section ) Contrôle des types à l exécution Compilateurs stricts et prévenants par exemple : Avertissement lorsqu une variable est affectée et non utilisée Erreur à l utilisation de variables non initialisées Erreur lorsque les exceptions ne sont pas gérées Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 15/169

Introduction au langage de programmation Java 1.4 Historique de l API 1 Introduction à Java Années de réalisation, et nombre de classes et d interfaces des versions de Java Java SE 7 2011 : 3 977 Java SE 6 2007 : 3 777 J2SE 5.0 2004 : 3 270 J2SE 1.4 2002 : 2 723 J2SE 1.3 2000 : 1 840 J2SE 1.2 1998 : 1 524 JDK 1.1 1997 : 477 JDK 1.0 1996 : 211 Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 16/169

Introduction au langage de programmation Java 1.5 Environnements de développement 1 Introduction à Java Java Development Kit : compilateur, JVM, Appletviewer... Eclipse, NetBeans, Jbuilder, Visual J++... Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 17/169

1 Introduction à Java 1.5 Environnements de développement 1.5.1 Java Standard Development Kit javac : compilateur java : JVM interpréteur de bytecode javadoc : générateur de documentation appletviewer : environnement pour applet javah : générateur d entêtes pour mélange avec code natif en C (JNI) javap : désassembleur de code intermédiaire jdb : dévermineur javakey : générateur de clés pour signer le code Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 18/169

Introduction au langage de programmation Java 1.6 En savoir plus 1 Introduction à Java Java Series : http://docs.oracle.com/javase// The Java Tutorial, Campione, Walrath, 5th edition, 2013, The Java Programming Language, Arnold, Gosling, Holmes, 5th edition, 2013, The Java Language Specification, J. Gosling, B. Joy, G. Steele, G. Bracha, A. Bukley, 4th edition, 2013, The Java Virtual Machine Specification, T. Lindholm, F. Yellin, G. Bracha, A. Bukley, 3rd edition, 2013 Livres D. Flanagan, «Java in a Nutshell : A Desktop Quick Reference, 5th Edition», O Reilly, 2005 D. Flanagan, «Java Examples in a nutshell : A Tutorial Companion to Java in a Nutshell», 3rd Edition, 2004 P. Niemeyer and J. Knudsen, «Learning Java», O Reilly, 2005 J. Bloch, «Effective Java, 2nd Edition», Addison Wesley, 2008 Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 19/169

1 Introduction à Java 1.6 En savoir plus 1.6.1 Sites Web http://moodle.tem-tsp.eu/moodle/view.php?id=26 http://www-inf.it-sudparis.eu/cours/csc4002/ http://http://www.oracle.com/technetwork/java/index.html: Oracle Java(tm) Technology Home Page http://www.javaworld.com: Infos http://www.developer.com/java: Infos Liens Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 20/169

Introduction au langage de programmation Java Questions sur les concepts Java 1 Introduction à Java En Java tout est-il objet? La machine virtuelle Java : garantit-elle l uniformité des variables de type primitif? met-elle en œuvre la gestion mémoire et en particulier le ramasse miettes? Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 21/169

Introduction au langage de programmation Java 2 Concepts de bases de Java 2.1 Syntaxe de base..............................................................23 2.2 Types Primitifs...............................................................27 2.3 Tableaux.................................................................... 32 2.4 Méthodes.................................................................... 33 2.5 Exemple de passage d arguments.............................................. 34 Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 22/169

Introduction au langage de programmation Java 2.1 Syntaxe de base 2 Concepts de bases de Java Syntaxe de base C Instructions de contrôle : if, switch, for, while, do while Opérateurs : tous les opérateurs du C par exemple, + - / *, Blocs, instructions simples : {}, «;» Quelques différences final remplace const espaces de nommage plus nombreux : classe, fichier, groupe de classes private remplace static static prend un sens associé au concept de classe Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 23/169

2 Concepts de bases de Java 2.1 Syntaxe de base 1 #i n c l u d e < s t d l i b. h> 2 #i n c l u d e <s t d i o. h> 3 t y p e d e f enum { FAUX=0, VRAI=1 } Booleen ; 4 5 s t a t i c Booleen e s t P r e m i e r ( i n t nombre ) { 6 i n t borne=nombre / 2 ; 7 8 i f ( nombre==1) r e t u r n FAUX ; 9 f o r ( i n t pred =2; pred<=borne ; pred++) { 10 i f ( nombre%pred==0) { 11 r e t u r n FAUX ; 12 } 13 } 14 r e t u r n VRAI ; 15 } 16 17 i n t main ( ) { 18 i n t nb ; 19 p r i n t f ( " S a i s i r une v a l e u r > 0 : " ) ; 20 s c a n f ( "%d ", &nb ) ; 21 22 i f ( nb<=0) { 2.1.1 Premier en C Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 24/169

2 Concepts de bases de Java 2.1 Syntaxe de base 23 p r i n t f ( " E r r e u r de s a i s i e \n " ) ; 24 r e t u r n EXIT_FAILURE ; 25 } 26 p r i n t f ( " Le nombre %d ", nb ) ; 27 i f ( e s t P r e m i e r ( nb ) ) { 28 p r i n t f ( " e s t p r e m i e r \n " ) ; 29 } e l s e { 30 p r i n t f ( " n e s t pas p r e m i e r \n " ) ; 31 } 32 r e t u r n EXIT_SUCCESS ; 33 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 25/169

2 Concepts de bases de Java 2.1 Syntaxe de base 2.1.2 Premier en Java 1 package complements. commeenc ; 2 p u b l i c c l a s s P r e m i e r { 3 p r i v a t e s t a t i c boolean e s t P r e m i e r ( f i n a l i n t nb ) { 4 i f ( nb == 1) { r e t u r n f a l s e ; } 5 f o r ( i n t i =2; i <= nb / 2 ; i ++) { 6 i f ( nb%i == 0) { 7 r e t u r n f a l s e ; 8 } 9 } 10 r e t u r n t r u e ; 11 } 12 p u b l i c s t a t i c v o i d main ( S t r i n g [ ] a r g s ) { 13 i n t nombre = C o n s o l e. r e a d I n t ( " E n t r e z un nombre e n t i e r " ) ; 14 System. out. p r i n t l n ( " Le nombre " + nombre + " e s t i l p r e m i e r? " ) ; 15 System. out. p r i n t ( " Le nombre " + nombre ) ; 16 i f ( e s t P r e m i e r ( nombre ) ) { 17 System. out. p r i n t l n ( " e s t p r e m i e r " ) ; 18 } e l s e { 19 System. out. p r i n t l n ( " n e s t pas p r e m i e r " ) ; 20 } 21 } 22 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 26/169

Introduction au langage de programmation Java 2.2 Types Primitifs 2 Concepts de bases de Java pas des classes short(2 octets), int (4 octets), long (8 octets) float (4 octets), double (8 octets) boolean (true/false), byte (1 octet), char (2 octets) Variables déclarées n importe où dans un bloc Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 27/169

2 Concepts de bases de Java 2.2 Types Primitifs 2.2.1 Conversions de type Conversions sur les types primitifs : Conversions sûres OK (d un type vers un type plus complexe) Conversions non sûres (d un type vers un type plus pauvre) nécessitent un transtypage (en anglais, cast) explicite Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 28/169

2 Concepts de bases de Java 2.2 Types Primitifs 2.2.2 Exemple de conversions 1 p u b l i c c l a s s CastExampleFixed { 2 p u b l i c s t a t i c v o i d main ( f i n a l S t r i n g [ ] a r g s ) { 3 i n t i = 2127272 ; // 0 x002075a8 4 l o n g m; 5 s h o r t s ; 6 byte b ; 7 m = i ; // promotion OK 8 // E x p l i c i t c a s t needed 9 i = ( i n t ) m; 10 s = ( s h o r t ) i ; // 0x75A8 11 b = ( byte ) i ; // 0xA8 12 System. out. p r i n t l n ( "m= " + m + " ; s= " + s + " ; b= " + b ) ; 13 } 14 } Résultat de l exécution : m= 2127272; s= 30120; b= -88; Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 29/169

2 Concepts de bases de Java 2.2 Types Primitifs 2.2.3 Tableaux Les tableaux sont des objets Leur taille est fixe Leur taille est allouée dynamiquement par l utilisation du mot réservé new L accès aux entrées est identique à celle en langage C une fois l allocation faite Erreur d accès en cas de dépassement de taille Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 30/169

2 Concepts de bases de Java 2.2 Types Primitifs 2.2.4 Exemple avec un tableau 1 p u b l i c c l a s s ArrayExample { 2 p u b l i c s t a t i c v o i d main ( S t r i n g [ ] a r g s ) { 3 i n t [ ] a r r a y O f I n t ; // o r i n t a r r a y O f I n t [ ] ; // d e c l a r a t i o n de l a v a r i a b l e a r r a y 4 a r r a y O f I n t = new i n t [ 4 2 ] ; // c r e a t i o n du t a b l e a u e t a s s o c i a t i o n a a r r a y O f I n t 5 a r r a y O f I n t [ 0 ] = 3 ; // a f f e c t a t i o n d un e l e m e n t du t a b l e a u 6 7 System. out. p r i n t l n ( " A r r a y l e n g t h "+ a r r a y O f I n t. l e n g t h ) ; // o b t e n t i o n de l a t a i l 8 System. out. p r i n t l n ( a r r a y O f I n t [ 4 2 ] ) ; // i m p o s s i b l e l e v e e d un e x c e p t i o n 9 } 10 } Résultat de l exécution : Array length 42 Exception in thread "main" java.lang.arrayindexoutofboundsexception: 42 at ArrayExample.main(ArrayExample.java:8) Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 31/169

Introduction au langage de programmation Java 2.3 Tableaux 2 Concepts de bases de Java Déclaration de la référence int[] arrayofint; // or int arrayofint[]; Création avec association de taille arrayofint = new int[42]; Taille int t = arrayofint.length; Compatibilité avec C : int[] primes = {1, 2, 3, 5, 7, 7+4}; Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 32/169

Introduction au langage de programmation Java 2.4 Méthodes 2 Concepts de bases de Java Nom donné aux opérations Méthodes associées aux classes (pas de méthode sans classe) Surcharge (en anglais, overloading) des méthodes possible Méthode d instance Méthode de classe avec mot réservé static Prototype de la méthode public static void main(final String []) Passage d arguments Par valeur pour les types primitifs Par référence pour les objets et les tableaux Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 33/169

Introduction au langage de programmation Java 2 Concepts de bases de Java 2.5 Exemple de passage d arguments 1 p u b l i c c l a s s EssParm { 2 p r i v a t e s t a t i c v o i d add ( i n t c, f i n a l i n t [ ] as ) { 3 c++; 4 as [ 0 ] ++; 5 System. out. p r i n t l n ( " add : c=" + c + ", as [0]= " + as [ 0 ] ) ; 6 } 7 p u b l i c s t a t i c v o i d main ( f i n a l S t r i n g a r g v [ ] ) { 8 i n t i = 0 ; 9 i n t s [ ] = new i n t [ 1 0 ] ; 10 s [ 0 ] = 0 ; 11 add ( i, s ) ; 12 System. out. p r i n t l n ( " main : i=" + i + ", s [0]= " + s [ 0 ] ) ; 13 } 14 } Résultat de l exécution : add : c=1, as[0]=1 main : i=0, s[0]=1 Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 34/169

Introduction au langage de programmation Java Questions sur la syntaxe de base de Java 2 Concepts de bases de Java En Java un fichier source peut-il contenir des méthodes? Dans un bloc d instructions (partie entre accolades) : la ligne suivante est-elle acceptable en C et en Java? int a = 0, b = 1, c; la ligne suivante est-elle acceptable en C et en Java? if ( a = b ) { c = a; } L accès à un élément de tableau est-il réalisé de manière identique en C et en Java? Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 35/169

Introduction au langage de programmation Java 3 Classes et objets en Java 3.1 Classe....................................................................... 37 3.2 Objet........................................................................ 41 3.3 Attributs et méthodes de classe............................................... 49 3.4 Association entre classes......................................................53 Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 36/169

Introduction au langage de programmation Java 3.1 Classe 3 Classes et objets en Java Classe Personne en UML Nom de la classe Attributs d instance de la classe Personne Personne Personne nom : String prénom : String nbparticipations : Integer = 0 nborganisations : Integer = 0 Constructeur(String n, String p) voter(bulletin b) consulterresultat(scrutin s) seretirerdunscrutin(scrutin s) nom : String prénom : String nbparticipations : Integer nborganisations : Integer Opérations d instance de la classe voter(bulletin) consulterresultat(scrutin) seretirerdunscrutin(scrutin) Personne Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 37/169

3 Classes et objets en Java 3.1 Classe 3.1.1 Classe Personne en Java 1 package s t u d s ; 2 p u b l i c c l a s s Personne { 3 p r i v a t e S t r i n g nom, prenom ; 4 p r i v a t e i n t n b P a r t i c i p a t i o n s = 0, n b O r g a n i s a t i o n s = 0 ; 5 p u b l i c Personne ( f i n a l S t r i n g n, f i n a l S t r i n g p ) { 6 nom = n ; prenom = p ; 7 } 8 p u b l i c v o i d v o t e r ( f i n a l B u l l e t i n b ){ } 9 p u b l i c v o i d c o n s u l t e r R e s u l t a t ( f i n a l S c r u t i n s ) { } 10 p u b l i c v o i d s e R e t i r e r D U n S c r u t i n ( f i n a l S c r u t i n s ) { } 11 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 38/169

3 Classes et objets en Java 3.1 Classe 3.1.2 Instance de classe en UML Nom de la classe Identifiant de l objet Personne j:personne nom : String prénom : String nbparticipations : Integer = 0 nborganisations : Integer =0 nom = "Dupont" prénom = "Julien" nbparticipations = 7 nborganisations = 3 Constructeur(String n,string p) voter(bulletin b) consulterresultat(scrutin s) seretirerdunscrutin(scrutin s) Type de l attribut Valeur de l attribut Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 39/169

3 Classes et objets en Java 3.1 Classe 3.1.3 Instance de classe en Java 1 import s t u d s. Personne ; 2 c l a s s I n i t P e r s o n n e { 3 p u b l i c s t a t i c v o i d main ( f i n a l S t r i n g [ ] a r g s ) { 4 Personne j ; // r e f e r e n c e 5 j = new Personne ( " Dupont ", " J u l i e n " ) ; // i n s t a n c e c r e a t i o n 6 System. out. p r i n t l n ( j ) ; 7 } 8 } Résultat de l exécution : studs.personne@f62373 Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 40/169

Introduction au langage de programmation Java 3 Classes et objets en Java 3.2 Objet Création d un objet Disposer d une référence : Personne p; Créer l objet : new + appel à un constructeur p = new Personne("Dupont", "Julien"); Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 41/169

3 Classes et objets en Java 3.2 Objet 3.2.1 Constructeurs en Java Méthode particulière : Nom identique à la classe Aucun type de retour Appelé directement à travers new Si aucun constructeur n est spécifié, le compilateur en fabrique un par défaut qui initialise les attributs à 0 (correspondant à leur type) La surcharge des méthodes (overloading) permet à une classe d avoir plusieurs constructeurs qui diffèrent par le nombre et le type de leurs arguments Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 42/169

3 Classes et objets en Java 3.2 Objet 3.2.2 Exemples de constructeurs 1 package s t u d s c t r s ; 2 import s t u d s. B u l l e t i n ; 3 import s t u d s. S c r u t i n ; 4 p u b l i c c l a s s Personne { 5 p r i v a t e S t r i n g nom, prenom ; 6 p r i v a t e i n t n b P a r t i c i p a t i o n s = 0, n b O r g a n i s a t i o n s = 0 ; 7 p u b l i c Personne ( f i n a l S t r i n g n, f i n a l S t r i n g p ) { 8 nom = n ; prenom = p ; 9 } 10 p u b l i c Personne ( f i n a l S t r i n g n, f i n a l S t r i n g p, 11 f i n a l i n t nbp, f i n a l i n t nbo ) { 12 nom = n ; prenom = p ; 13 n b P a r t i c i p a t i o n s = nbp ; n b O r g a n i s a t i o n s = nbo ; 14 } 15 p u b l i c v o i d v o t e r ( f i n a l B u l l e t i n b ) { } 16 p u b l i c v o i d c o n s u l t e r R e s u l t a t ( f i n a l S c r u t i n s ) { } 17 p u b l i c v o i d s e R e t i r e r D U n S c r u t i n ( f i n a l S c r u t i n s ) { } 18 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 43/169

3 Classes et objets en Java 3.2 Objet 3.2.3 this this permet de référencer l instance courante ; Est associé au concept d auto-référence de l objet this permet de décrire un attribut ou une méthode de l instance courante sans ambiguïté this(...) en tant que méthode fait appel à un constructeur Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 44/169

3 Classes et objets en Java 3.2 Objet 3.2.4 Exemples d utilisation de this 1 package s t u d s t h i s ; 2 import s t u d s. B u l l e t i n ; 3 import s t u d s. S c r u t i n ; 4 p u b l i c c l a s s Personne { 5 p r i v a t e S t r i n g nom, prenom ; 6 p r i v a t e i n t n b P a r t i c i p a t i o n s = 0, n b O r g a n i s a t i o n s = 0 ; 7 8 p u b l i c Personne ( f i n a l S t r i n g nom, f i n a l S t r i n g prenom ) { 9 t h i s. nom = nom ; t h i s. prenom = prenom ; 10 } 11 p u b l i c Personne ( f i n a l S t r i n g n, f i n a l S t r i n g p, 12 f i n a l i n t nbp, f i n a l i n t nbo ) { 13 t h i s ( n, p ) ; 14 n b P a r t i c i p a t i o n s = nbp ; n b O r g a n i s a t i o n s = nbo ; 15 } 16 v o i d v o t e r ( f i n a l B u l l e t i n b ){ } 17 v o i d c o n s u l t e r R e s u l t a t ( f i n a l S c r u t i n s ) { } 18 v o i d s e R e t i r e r D U n S c r u t i n ( f i n a l S c r u t i n s ) { } 19 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 45/169

3 Classes et objets en Java 3.2 Objet 3.2.5 Destruction des objets Pas de technique particulière pour détruire un objet Objet détruit lorsqu il n est plus référencé Utilisation d un ramasse miettes Le Garbage Collector détruit les objets non référencés La destruction est asynchrone Il n y a pas de garantie sur la destruction (le programme peut se terminer avant que l objet ne soit détruit) Si la classe décrit une méthode appelée finalize, cette méthode est appelée avant la libération de la mémoire de l objet Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 46/169

3 Classes et objets en Java 3.2 Objet 3.2.6 Abstraction et encapsulation Une classe correspond aux concepts d abstraction et d encapsulation C est une abstraction car elle présente une interface (ensemble de méthodes) qui permettent d interagir avec les objets Une classe encapsule des données (ensemble d attributs) Pour garantir sa robustesse et son indépendance du reste du code, une classe doit masquer son implantation En particulier, elle ne doit pas permettre la modification de ses attributs sans contrôle Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 47/169

3 Classes et objets en Java 3.2 Objet 3.2.7 Visibilité des méthodes Les méthodes publiques (public) d une classe définissent son interface publique Les méthodes privées (private), ne sont accessibles que depuis l intérieur de la classe Les méthodes protégées (protected), sont accessibles depuis l intérieur de la classe et de l intérieur de ses classes dérivées Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 48/169

Introduction au langage de programmation Java 3.3 Attributs et méthodes de classe 3 Classes et objets en Java Attribut d instance Attribut de classe Opération d instance Opération de classe Personne nom : String prénom : String nbparticipations : Integer nborganisation : Integer nbtotalparticipations : Integer Constructeur(String n, String p) voter(bulletin) consulterresultat() seretirerdunscrutin() getnbtotalparticipations() j:personne nom = Dupont prénom = Julien nbparticipations = 7 nborganisation = 3 nbtotalparticipations = 12 nom = Martin prénom = Marie nbparticipations = 5 nborganisation = 1 m:personne Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 49/169

3 Classes et objets en Java 3.3 Attributs et méthodes de classe 3.3.1 Attributs et méthodes de classe Java 1 package s t u d s s t a t ; 2 p u b l i c c l a s s Personne { 3 p r i v a t e S t r i n g nom, prenom ; 4 p r i v a t e i n t n b P a r t i c i p a t i o n s = 0, n b O r g a n i s a t i o n s = 0 ; 5 p r i v a t e s t a t i c i n t n b T o t a l P a r t i c i p a t i o n s = 0 ; 6 p u b l i c Personne ( f i n a l S t r i n g nom, f i n a l S t r i n g prenom ){ 7 t h i s. nom = nom ; t h i s. prenom = prenom ; 8 } 9 p u b l i c Personne ( f i n a l S t r i n g nom, f i n a l S t r i n g prenom, 10 f i n a l i n t nbp, f i n a l i n t nbo ) { 11 t h i s (nom, prenom ) ; 12 n b P a r t i c i p a t i o n s = nbp ; 13 n b T o t a l P a r t i c i p a t i o n s += nbp ; 14 n b O r g a n i s a t i o n s = nbo ; 15 } 16 p u b l i c s t a t i c i n t g e t N b T o t a l P a r t i c i p a t i o n s ( ) { 17 r e t u r n n b T o t a l P a r t i c i p a t i o n s ; 18 } 19 p u b l i c S t r i n g t o S t r i n g ( ) { 20 r e t u r n nom + " " + prenom + " nbp " + n b P a r t i c i p a t i o n s 21 + " nbo " + n b O r g a n i s a t i o n s + " nbt " 22 + n b T o t a l P a r t i c i p a t i o n s ; Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 50/169

3 Classes et objets en Java 3.3 Attributs et méthodes de classe 23 } 24 } 1 import s t u d s s t a t. Personne ; 2 p u b l i c c l a s s T e s t S t a t i c P e r s o n n e { 3 p u b l i c s t a t i c v o i d main ( f i n a l S t r i n g [ ] a r g s ) { 4 Personne j = new Personne ( " Dupont ", " J u l i e n ", 7, 3 ) ; 5 Personne m = new Personne ( " Martin ", " Marie ", 5, 1 ) ; 6 System. out. p r i n t l n ( j ) ; 7 System. out. p r i n t l n (m) ; 8 } 9 } Affichage : Dupont Julien nbp 7 nbo 3 nbt 12 Martin Marie nbp 5 nbo 1 nbt 12 Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 51/169

3 Classes et objets en Java 3.3 Attributs et méthodes de classe 3.3.2 Attributs et méthodes de classe Les attributs statiques sont partagés par toutes les instances de la classe Les méthodes statiques ne peuvent accéder qu aux attributs statiques Il n est pas nécessaire d instancier la classe pour accéder à ses membres statiques Les instances peuvent accéder aux attributs statiques Les instances peuvent invoquer les méthodes statiques Les méthodes statiques ne sont jamais associées à l auto référence de l objet (this) Quelques exemples avec la classe java.lang.math : pi = Math.PI; // static attribute PI b = Math.sqrt(2.0);// method call of static sqrt Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 52/169

Introduction au langage de programmation Java 3.4 Association entre classes 3 Classes et objets en Java Association Nom de l association Sens de lecture de l association Personne organise * Scrutin m:personne organise listebde:scrutin Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 53/169

3 Classes et objets en Java 3.4 Association entre classes 3.4.1 Exemple d association 1 package s t u d s o r g ; 2 p u b l i c c l a s s Personne { 3 p r i v a t e S t r i n g nom, prenom ; 4 p r i v a t e i n t n b P a r t i c i p a t i o n s = 0, n b O r g a n i s a t i o n s = 0 ; 5 p r i v a t e S c r u t i n [ ] s c r u t i n s O r g a n i s e s ; 6 p u b l i c Personne ( f i n a l S t r i n g nom, f i n a l S t r i n g prenom ) { 7 t h i s. nom = nom ; t h i s. prenom = prenom ; 8 s c r u t i n s O r g a n i s e s = new S c r u t i n [ 1 0 ] ; 9 } 10 p u b l i c S c r u t i n o r g a n i s e r S c r u t i n ( f i n a l S t r i n g nom){ 11 S c r u t i n s = new S c r u t i n (nom ) ; 12 s c r u t i n s O r g a n i s e s [ n b O r g a n i s a t i o n s ] = s ; 13 n b O r g a n i s a t i o n s ++; 14 r e t u r n s ; 15 } 16 p u b l i c S t r i n g t o S t r i n g ( ) { 17 r e t u r n g e t C l a s s ( ). getname ( ) + " "+nom+" "+prenom+" nbp " 18 + n b P a r t i c i p a t i o n s + " nbo " + n b O r g a n i s a t i o n s ; 19 } 20 } 1 package s t u d s o r g ; Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 54/169

3 Classes et objets en Java 3.4 Association entre classes 2 p u b l i c c l a s s S c r u t i n { 3 p r i v a t e S t r i n g nomscrutin ; 4 p u b l i c S c r u t i n ( f i n a l S t r i n g nom) { 5 nomscrutin = nom ; 6 } 7 / @see j a v a. l a n g. O b j e c t#t o S t r i n g ( ) / 8 @ O v e r r i d e 9 p u b l i c S t r i n g t o S t r i n g ( ) { 10 r e t u r n " S c r u t i n [ nomscrutin=" + nomscrutin + " ] " ; 11 } 12 13 } 1 import s t u d s o r g. ; 2 p u b l i c c l a s s I n i t S c r u t i n { 3 p u b l i c s t a t i c v o i d main ( f i n a l S t r i n g [ ] a r g s ) { 4 Personne p ; // r e f e r e n c e 5 p = new Personne ( " Dupont ", " J u l i e n " ) ; // i n s t a n c e c r e a t i o n 6 S c r u t i n bde = p. o r g a n i s e r S c r u t i n ( " E l e c t i o n bde 2010 " ) ; 7 } 8 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 55/169

3 Classes et objets en Java 3.4 Association entre classes 3.4.2 Association entre classes en Java Mise en place à l aide d attributs Dans l une ou l autre des classes selon la navigabilité de l association Mise en place au moment de la construction des instances Multiplicité de l association représentée à l aide d un tableau ou d une collection Difficulté lorsque l association est bidirectionnelle, par quoi commencer? Utilisation d une méthode qui permet d affecter un attribut d une classe en dehors du constructeur Passage de la référence d un des objets dans l appel au constructeur de l autre Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 56/169

Introduction au langage de programmation Java Questions sur les classes et objet 3 Classes et objets en Java Les attributs d instance d une classe servent-ils à représenter l état des objets de la classe? Les objets sont-ils créés par l appel à un constructeur de la classe? Dans la section 50, est-il légal d écrire : ligne 12 this.nbparticipations au lieu de nbparticipations ligne 17 this.nbtotalparticipations au lieu de nbtotalparticipations Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 57/169

Introduction au langage de programmation Java 4 Généralisation spécialisation en Java 4.1 Généralisation spécialisation.................................................. 59 4.2 Polymorphisme.............................................................. 66 4.3 Redéfinition de méthodes dans les classes dérivées............................. 69 4.4 Héritage, membres et visibilité................................................ 71 4.5 Classes abstraites............................................................ 73 4.6 Exemple de classe Abstraites..................................................76 4.7 Interfaces.................................................................... 81 Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 58/169

Introduction au langage de programmation Java 4.1 Généralisation spécialisation 4 Généralisation spécialisation en Java Personne nom numérosécu Avocat nombreaffaires adressecabinet Vendeur ancienneté nomdustand Enseignant nombrecours specialité Permanent numérobureau Vacataire nombrevacations Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 59/169

4 Généralisation spécialisation en Java 4.1 Généralisation spécialisation 4.1.1 Héritage : comment en Java Une classe ne peut hériter que d une autre classe (héritage simple) Une classe hérite d une autre par l utilisation du mot réservé extends Une classe pour laquelle aucune spécialisation n est explicitée spécialise implicitement la classe java.lang.object L opérateur instanceof permet de tester si une référence correspond à un objet d une classe donnée Le mot réservé final utilisé devant le mot clé class interdit toute spécialisation de la classe sur laquelle il est utilisé Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 60/169

4 Généralisation spécialisation en Java 4.1 Généralisation spécialisation 4.1.2 Héritage et constructeur Création d un objet de classe dérivée = création de la partie de l objet correspondant à la classe parente Appel dans le constructeur de la classe dérivée d un des constructeurs de la classe parente par utilisation du mot réservé super() En première ligne du constructeur de la classe enfant Si aucun appel = appel au constructeur sans argument de la classe parente Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 61/169

4 Généralisation spécialisation en Java 4.1 Généralisation spécialisation 4.1.3 Exemple de classe parente et classe dérivée 1 package p e r s o n n e s ; 2 p u b l i c c l a s s Personne { 3 p r i v a t e S t r i n g nom, prenom, numsecu ; 4 p u b l i c Personne ( f i n a l S t r i n g n, f i n a l S t r i n g p, f i n a l S t r i n g ns ){ 5 nom = n ; prenom = p ; numsecu = n s ; 6 } 7 p u b l i c S t r i n g t o S t r i n g ( ) { 8 r e t u r n " Personne : " + nom + " " + prenom + " " + numsecu ; 9 } 10 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 62/169

4 Généralisation spécialisation en Java 4.1 Généralisation spécialisation 1 package p e r s o n n e s ; 2 p u b l i c c l a s s E n s e i g n a n t extends Personne { 3 p r i v a t e i n t nbcours ; p r i v a t e S t r i n g s p e c i a l i t e ; 4 p u b l i c E n s e i g n a n t ( f i n a l S t r i n g n, f i n a l S t r i n g p, f i n a l S t r i n g ns, 5 f i n a l i n t nbc, f i n a l S t r i n g s p e c i a l i t e ) { 6 s u p e r ( n, p, ns ) ; 7 nbcours = nbc ; 8 t h i s. s p e c i a l i t e = s p e c i a l i t e ; 9 } 10 p u b l i c S t r i n g t o S t r i n g ( ) { 11 r e t u r n " E n s e i g n a n t : " + nbcours + " " +s p e c i a l i t e ; 12 } 13 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 63/169

4 Généralisation spécialisation en Java 4.1 Généralisation spécialisation 4.1.4 Utilisation de classe parente et dérivée 1 import p e r s o n n e s. ; 2 p u b l i c c l a s s I n h e r i t E x a m p l e { 3 p u b l i c s t a t i c v o i d main ( f i n a l S t r i n g [ ] a r g s ) { 4 Personne p = new Personne ( " Dupont ", " J u l i e n ", 5 " 1 8 3 1 2 9 1... " ) ; 6 E n s e i g n a n t e = new E n s e i g n a n t ( " Durand ", " E m i l i e ", 7 " 2 7 8 0 6 3 3... ", 3, " Cloud Computing " ) ; 8 System. out. p r i n t l n ( " p e s t une Personne " 9 + ( p i n s t a n c e o f Personne ) ) ; 10 System. out. p r i n t l n ( " p e s t un E n s e i g n a n t " 11 + ( p i n s t a n c e o f E n s e i g n a n t ) ) ; 12 13 System. out. p r i n t l n ( " e e s t une Personne " 14 + ( e i n s t a n c e o f Personne ) ) ; 15 System. out. p r i n t l n ( " e e s t un E n s e i g n a n t " 16 + ( e i n s t a n c e o f E n s e i g n a n t ) ) ; 17 } 18 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 64/169

4 Généralisation spécialisation en Java 4.1 Généralisation spécialisation Résultat de l exécution : p est une Personne true p est une Enseignant false e est une Personne true e est une Enseignant true Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 65/169

Introduction au langage de programmation Java 4.2 Polymorphisme 4 Généralisation spécialisation en Java Affectation de références dans un arbre d héritage Upcast : une référence d une classe B peut référencer toute instance de la classe B ou de ses classes dérivées Downcast : une référence d une classe D dérivée d une classe B peut recevoir une référence de la classe B si et seulement si : L objet référencé est bien du type D ou d un de ses types dérivés Le changement de type doit être explicite (en anglais, cast) vers le nouveau type (D) Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 66/169

4 Généralisation spécialisation en Java 4.2 Polymorphisme 1 import p e r s o n n e s. Personne ; 2 import p e r s o n n e s. E n s e i g n a n t ; 3 p u b l i c c l a s s UpDownExample { 4.2.1 Exemple de Upcast et Downcast 4 p u b l i c s t a t i c v o i d main ( f i n a l S t r i n g [ ] a r g s ) { 5 Personne p ; 6 E n s e i g n a n t e = new E n s e i g n a n t ( " Durand ", " E m i l i e ", 7 " 2 7 8 0 6 3 3... ", 3, " Cloud Computing " ) ; 8 p = e ; // UpCast 9 System. out. p r i n t l n ( " Apres p = e ; p e s t une Personne " 10 + ( p i n s t a n c e o f Personne ) 11 + " ; p e s t un E n s e i g n a n t " 12 + ( p i n s t a n c e o f E n s e i g n a n t ) ) ; 13 e = ( E n s e i g n a n t ) p ; // Downcast 14 System. out. p r i n t l n ( " Apres e = p ; e e s t une Personne " 15 + ( e i n s t a n c e o f Personne ) 16 + " ; e e s t un E n s e i g n a n t " 17 + ( e i n s t a n c e o f E n s e i g n a n t ) ) ; 18 } 19 } Apres p = e; p est une Personne true Apres p = e; p est un Enseignant true Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 67/169

4 Généralisation spécialisation en Java 4.2 Polymorphisme Apres e=p; e est une Personne true Apres e=p; e est un Enseignant true Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 68/169

Introduction au langage de programmation Java 4 Généralisation spécialisation en Java 4.3 Redéfinition de méthodes dans les classes dérivées Redéfinition possible des méthodes publiques héritées (en anglais overriding) Peut être annotée par @Override. Liaison dynamique : Redéfinition la plus proche dans l arbre d héritage invoquée Même à travers une référence d une classe parente Accès explicite à une méthode redéfinie de la classe parente par super Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 69/169

4 Généralisation spécialisation en Java 4.3 Redéfinition de méthodes dans les classes dérivées 4.3.1 Polymorphisme et liaison dynamique avec tostring 1 import p e r s o n n e s. Personne ; 2 import p e r s o n n e s. E n s e i g n a n t ; 3 p u b l i c c l a s s TestPolyMorph { 4 p u b l i c s t a t i c v o i d main ( f i n a l S t r i n g [ ] a r g s ) { 5 Personne p = new Personne ( " Dupont ", " J u l i e n ", 6 " 1 8 3 1 2 9 1... " ) ; 7 E n s e i g n a n t e = new E n s e i g n a n t ( " Durand ", " E m i l i e ", 8 " 2 7 8 0 6 3 3... ", 3, " Cloud Computing " ) ; 9 System. out. p r i n t l n ( p. t o S t r i n g ( ) ) ; 10 System. out. p r i n t l n ( e. t o S t r i n g ( ) ) ; 11 p = e ; // UpCast 12 System. out. p r i n t l n ( p. t o S t r i n g ( ) ) ; 13 } 14 } Personne: Dupont Julien Enseignant: 3 Cloud Computing Enseignant: 3 Cloud Computing Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 70/169

Introduction au langage de programmation Java 4.4 Héritage, membres et visibilité 4 Généralisation spécialisation en Java Une classe D héritant d une classe B hérite de tous ses membres : Les membres private de B sont inaccessibles depuis D Les membres protected de B sont accessibles depuis D Les membres public sont accessibles depuis D comme depuis les autres classes Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 71/169

Introduction au langage de programmation Java 4 Généralisation spécialisation en Java Questions généralisation/spécialisation en Java À quoi sert le mot réservé extends dans une déclaration de classe? À quoi sert le mot super? Peut-on interdire la redéfinition d une méthode dans une classe dérivée? Peut-on interdire la généralisation/spécialisation d une classe? Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 72/169

Introduction au langage de programmation Java 4.5 Classes abstraites 4 Généralisation spécialisation en Java En UML : << abstract >> Média auteur titre datecréation transporter() dupliquer() afficher() Nom de la classe en italique ou utilisation du stéréotype <<abstract>> Livre Texte Graphique Vidéo longueur largeur hauteur durée afficher() afficher() afficher() afficher() Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 73/169

4 Généralisation spécialisation en Java 4.5 Classes abstraites 4.5.1 Classes abstraites : principes Classe qui ne peut pas être instanciée. Par exemple la classe Média de la diapositive précédente Spécialisation nécessaire jusqu à obtenir des classes instanciables : par exemple, la classe Livre dans la même diapositive Impose un comportement commun à toutes les classes dérivées Possibilité de créer des tableaux ou des collections de références de classe abstraite Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 74/169

4 Généralisation spécialisation en Java 4.5 Classes abstraites 4.5.2 Classes abstraites en Java Méthodes abstraites sans corps de méthode Classe abstraite si méthode abstraite Classe dérivée : définit toutes les méthodes ou reste abstraite Classe qualifiée abstraite pour empêcher la création d instances Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 75/169

Introduction au langage de programmation Java 4.6 Exemple de classe Abstraites 4 Généralisation spécialisation en Java * nbtotalparticipations nbtotalorganisations nbparticipations nborganisations prenom nom * Personne concerne * * Bulletin pouroucontre concerne organise * * Scrutin intituléscrutin textecommentairescrutin datecréation datedébut datelimite datelimiteexistence ouvertureavancée fermetureavancée destructionavancée nbtotalscrutin nbchoix ScrutinPlagesHoraires nbtotal * PlageHoraire date heuredébut heurefin ScrutinPréférences nbtotal * Préférence intitulépréférence textecommentairepréf Studs * concerne * Choix /nbbulletinspour /nbbulletinscontre Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 76/169

4 Généralisation spécialisation en Java 4.6 Exemple de classe Abstraites 4.6.1 Exemple : classes abstraites 1 package s t u d s a b s t r a c t ; 2 p u b l i c a b s t r a c t c l a s s Choix { 3 p r i v a t e B u l l e t i n [ ] l e s B u l l e t i n s ; 4 i n t n b B u l l e t i n s P o u r, n b B u l l e t i n s C o n t r e, i n d e x B u l l e t i n s ; 5 p u b l i c Choix ( ) { 6 l e s B u l l e t i n s = new B u l l e t i n [ 1 0 0 ] ; 7 i n d e x B u l l e t i n s = 0 ; 8 n b B u l l e t i n s P o u r = 0 ; 9 n b B u l l e t i n s C o n t r e = 0 ; 10 } 11 p u b l i c i n t a d d B u l l e t i n ( B u l l e t i n b ) { 12 l e s B u l l e t i n s [ i n d e x B u l l e t i n s ++] = b ; 13 i f ( b. g e t V a l u e ( ) ) { 14 n b B u l l e t i n s P o u r++ ; 15 } e l s e { 16 n b B u l l e t i n s C o n t r e++ ; 17 } 18 r e t u r n i n d e x B u l l e t i n s ; 19 } 20 p u b l i c i n t g e t N b B u l l e t i n s P o u r ( ) { 21 r e t u r n n b B u l l e t i n s P o u r ; 22 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 77/169

4 Généralisation spécialisation en Java 4.6 Exemple de classe Abstraites 23 p u b l i c i n t g e t N b B u l l e t i n s C o n t r e ( ) { 24 r e t u r n n b B u l l e t i n s C o n t r e ; 25 } 26 p u b l i c i n t c h e r c h e r R a n g ( B u l l e t i n b ){ 27 f o r ( i n t i = 0 ; i < i n d e x B u l l e t i n s ; i ++){ 28 i f ( b. e q u a l s ( l e s B u l l e t i n s [ i ] ) ) r e t u r n i ; 29 } 30 r e t u r n 1; 31 } 32 p u b l i c v o i d r e t i r e r B u l l e t i n ( f i n a l B u l l e t i n r e t r a i t ) { 33 i n t rang = c h e r c h e r R a n g ( r e t r a i t ) ; 34 i f ( rang > 1){ 35 c o m p a c t e r B u l l e t i n s ( rang ) ; 36 } 37 } 38 p u b l i c v o i d c o m p a c t e r B u l l e t i n s ( i n t r ){ 39 f o r ( i n t i = r ; i < i n d e x B u l l e t i n s ; i ++){ 40 l e s B u l l e t i n s [ i ] = l e s B u l l e t i n s [ i +1]; 41 } 42 i n d e x B u l l e t i n s ; 43 } 44 p u b l i c v o i d m o d i f i e r B u l l e t i n ( f i n a l B u l l e t i n changed ) { 45 i n t rang = c h e r c h e r R a n g ( changed ) ; 46 i f ( rang >=0) { Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 78/169

4 Généralisation spécialisation en Java 4.6 Exemple de classe Abstraites 47 B u l l e t i n achanger = l e s B u l l e t i n s [ rang ] ; 48 i f ( achanger. g e t V a l u e ( )!= changed. g e t V a l u e ( ) ) { 49 achanger. s e t V a l u e ( changed. g e t V a l u e ( ) ) ; 50 } 51 i f ( achanger. g e t V a l u e ( ) ) { 52 n b B u l l e t i n s C o n t r e ; 53 n b B u l l e t i n s P o u r ++; 54 } e l s e { 55 n b B u l l e t i n s C o n t r e++ ; 56 n b B u l l e t i n s P o u r ; 57 } 58 } 59 } 60 } 1 package s t u d s a b s t r a c t ; 2 import s t u d s. Personne ; 3 import s t u d s. B u l l e t i n ; 4 p u b l i c c l a s s Studs { 5 p r i v a t e Choix [ ] l e s C h o i x ; 6 p r i v a t e S c r u t i n [ ] l e s S c r u t i n s ; 7 p r i v a t e B u l l e t i n [ ] l e s B u l l e t i n s ; 8 p r i v a t e Personne [ ] l e s P a r t i c i p a n t s ; 9 p u b l i c Studs ( ) { Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 79/169

4 Généralisation spécialisation en Java 4.6 Exemple de classe Abstraites 10 l e s C h o i x = new Choix [ 1 0 0 ] ; 11 l e s S c r u t i n s = new S c r u t i n [ 1 0 0 ] ; 12 l e s B u l l e t i n s = new B u l l e t i n [ 1 0 0 ] ; 13 l e s P a r t i c i p a n t s = new Personne [ 1 0 0 ] ; 14 } 15 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 80/169

Introduction au langage de programmation Java 4.7 Interfaces 4 Généralisation spécialisation en Java UML : <<interface>> Déplaçable saplace() avancer() reculer() monter() descendre() Polygone sommets saplace() avancer() reculer() monter() descendre() Personne nom numsécu saplace() avancer() reculer() monter() descendre() Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 81/169

4 Généralisation spécialisation en Java 4.7 Interfaces 4.7.1 Interfaces en Java Les membres d une interface sont principalement des méthodes abstraites Une interface est déclarée avec le mot réservé interface Une interface peut hériter (extends) de plusieurs interfaces Une classe peut implémenter (implements) une ou plusieurs interfaces Rappel : une classe n hérite (extends) que d une seule classe Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 82/169

Introduction au langage de programmation Java 5 Organisation des sources Java 5.1 Programme en C (rappel).................................................... 84 5.2 Exécution d un programme (rappel)........................................... 85 5.3 Exécution d un programme sur une machine virtuelle........................... 86 5.4 Dans le cas de Java.......................................................... 87 5.5 Unités de compilation........................................................ 88 5.6 Paquetages.................................................................. 89 5.7 Visibilité en Java............................................................. 92 Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 83/169

Introduction au langage de programmation Java 5 Organisation des sources Java 5.1 Programme en C (rappel) PROGRAMME fichier1.c (source) (module) fichier2.c (source) (module) fichier3.c (source) (module) Compilation Compilation Compilation fichier1.o (objet) (binaire) (relogeable) fichier2.o (objet) (binaire) (relogeable) Edition de Liens fichier3.o (objet) (binaire) (relogeable) libc.a a.out (exécutable) (binaire) (chargeable) Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 84/169

Introduction au langage de programmation Java 5 Organisation des sources Java 5.2 Exécution d un programme (rappel) Processus Donnees Pile Tas Libc.so Texte Operating System CPU Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 85/169

Introduction au langage de programmation Java 5 Organisation des sources Java 5.3 Exécution d un programme sur une machine virtuelle 00 11 00 11 00 11 01 01 01 01 01 01 01 01 01 01 01 JVM 00 11 00 11 00 11 Donnees fichiers.class Pile Tas Libc.so Texte Operating System CPU Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 86/169

Introduction au langage de programmation Java 5.4 Dans le cas de Java 5 Organisation des sources Java Point d entrée public static void main(string args[]) dans une classe Classes chargées à la demande (en anglais dynamic loading) Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 87/169

Introduction au langage de programmation Java 5.5 Unités de compilation 5 Organisation des sources Java Un fichier source Java = une unité de compilation Recommandation : une seule classe par fichier source Obligation : nom du fichier source = nom de sa classe publique Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 88/169

Introduction au langage de programmation Java 5.6 Paquetages 5 Organisation des sources Java Paquetages : regroupement de classes dans un espace de nommage Noms des classes : «packagename.classname» Espace de nommage associé à la compilation et à l exécution Classe Personne du paquetage studs doit être dans un fichier correspondant au chemin «studs/personne.java» Ceci permet au compilateur et à la JVM de trouver les fichiers compilés Mot réservé package : nom de paquetage des classes dans l unité de compilation Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 89/169

5 Organisation des sources Java 5.6 Paquetages 5.6.1 Chemin de recherche variable d environnement CLASSPATH liste des répertoires de recherche pour le compilateur et la JVM Noms des classes complets contient le nom de paquetage import : permet d établir un alias API Java est organisée en paquetages (java.lang, java.io...) Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 90/169

5 Organisation des sources Java 5.6 Paquetages CLASSPATH : CLASSPATH=/src:/java 5.6.2 Exemple Fichier /java/studs/personne.java contient le code suivant : package studs; public class Personne { private String nom, prenom; private int nbparticipations = 0, nborganisations = 0; } public Personne(String n, String p){ n = nom; prenom = p; } public void voter(bulletin b){ } public void consulterresultat(scrutin s) { } public void seretirerdunscrutin(scrutin s) { } Fichier InitPersonne.java dans le répertoire /src peut contenir le code suivant : import studs.personne; class InitPersonne { public static void main(string[] args) { Personne j; j = new Personne("Dupont", "Julien"); System.out.println(j); } } // reference // instance creation Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 91/169

Introduction au langage de programmation Java 5.7 Visibilité en Java 5 Organisation des sources Java Un membre de la classe C peut être : private : accessible seulement à la classe package friendly (défaut) : accessible aux classes dans le même paquetage protected : accessible aux classed du paquetage et à toute classe dérivée en dehors du paquetage public : accessible à toutes les classes Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 92/169

5 Organisation des sources Java 5.7 Visibilité en Java 5.7.1 Table de visibilité package p1; class C1 { public int a; protected int b; int c; // friendly private int d; } class C2 extends C1 {... } class C3 {... } package p2; class C4 extends C1 {... } class C5 {... } a b c d Accessible de C2 oui oui oui - Accessible de C3 oui oui oui - Accessible de C4 oui oui - - Accessible de C5 oui - - - Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 93/169

Introduction au langage de programmation Java Questions organisation des sources en Java 5 Organisation des sources Java Le nom d un paquetage est-il lié à l organisation des fichiers sources? Dans quel paquetage se trouve java.lang.object? Les paquetages servent-ils seulement à la compilation des classes? Les paquetages impactent-ils la visibilité des membres des classes? Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 94/169

Introduction au langage de programmation Java 6 API Java 6.1 Premières classes de l API.................................................... 96 6.2 Classe java.lang.object....................................................... 97 6.3 Interface de programmation..................................................101 6.4 java.lang.*..................................................................103 6.5 java.util.*...................................................................108 Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 95/169

Introduction au langage de programmation Java 6.1 Premières classes de l API 6 API Java java.lang.object java.lang.string java.lang.integer Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 96/169

Introduction au langage de programmation Java 6.2 Classe java.lang.object 6 API Java public String tostring() protected Object clone() throws CloneNotSupportedException public boolean equals(object obj) protected void finalize() throws Throwable public final Class getclass() public int hashcode() Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 97/169

6 API Java 6.2 Classe java.lang.object 6.2.1 Égalité Les objets sont manipulés par des références o1 == o2 Teste si les références sont égales o1.equals(o3) Teste si le contenu de l objet référencé par o3 est comparable au contenu de l objet référencé par o1 o1 o2 obj1 "texte" o3 obj2 "texte" Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 98/169

6 API Java 6.2 Classe java.lang.object 6.2.2 Exemple d égalité 1 p u b l i c c l a s s S t r i n g E q u a l s { 2 p u b l i c s t a t i c v o i d main ( f i n a l S t r i n g a r g v [ ] ) { 3 S t r i n g s = " Ja ", j = " Java " ; 4 S t r i n g m = s + " va " ; 5 System. out. p r i n t l n (m) ; 6 i f ( j == m) { System. out. p r i n t l n ( " j == m V r a i " ) ; 7 } e l s e { System. out. p r i n t l n ( " j == m Faux " ) ; 8 } 9 i f ( j. e q u a l s (m) ) { 10 System. out. p r i n t l n ( " j. e q u a l s (m) V r a i " ) ; 11 } e l s e { 12 System. out. p r i n t l n ( " j. e q u a l s (m) Faux " ) ; 13 } 14 } 15 } Traces d exécution : Java j == m Faux j.equals(m) Vrai Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 99/169

6 API Java 6.2 Classe java.lang.object 6.2.3 Exemple de méthode equals 1 package s t u d s e q u a l s ; 2 p u b l i c c l a s s Personne { 3 p r i v a t e S t r i n g nom, prenom ; 4 p u b l i c Personne ( f i n a l S t r i n g nom, f i n a l S t r i n g prenom ){ 5 t h i s. nom = nom ; t h i s. prenom = prenom ; 6 } 7 @ O v e r r i d e 8 p u b l i c boolean e q u a l s ( O b j e c t o b j ) { 9 i f ( t h i s == o b j ) r e t u r n t r u e ; 10 i f ( o b j == n u l l ) r e t u r n f a l s e ; 11 i f (! ( o b j i n s t a n c e o f Personne ) ) r e t u r n f a l s e ; 12 Personne o t h e r = ( Personne ) o b j ; 13 i f (nom == n u l l ) { 14 i f ( o t h e r. nom!= n u l l ) r e t u r n f a l s e ; 15 } e l s e i f (! nom. e q u a l s ( o t h e r. nom ) ) r e t u r n f a l s e ; 16 i f ( prenom == n u l l ) { 17 i f ( o t h e r. prenom!= n u l l ) r e t u r n f a l s e ; 18 } e l s e i f (! prenom. e q u a l s ( o t h e r. prenom ) ) r e t u r n f a l s e ; 19 r e t u r n t r u e ; 20 } 21 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 100/169

Introduction au langage de programmation Java 6.3 Interface de programmation 6 API Java API Java organisée en paquetages java.lang.* importé de manière automatique Interface de programmation disponible quelle que soit la plate-forme Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 101/169

6 API Java 6.3 Interface de programmation 6.3.1 Quelques paquetages Java java.lang java.util java.io java.net Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 102/169

Introduction au langage de programmation Java 6 API Java <<Interface>> Cloneable <<Interface>> Comparable <<Interface>> Iterable Object 6.4 java.lang.* Boolean Character Class Math <<Abstract>> Number <<Abstract>> Process Runtime String StringBuffer System Byte Double Float Integer Long Short <<Interface>> Runnable Thread ThreadGroup Throwable Void Boolean Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 103/169

6 API Java 6.4 java.lang.* 6.4.1 Exemple avec la classe Integer 1 p u b l i c c l a s s I n t E x a m p l e { 2 p u b l i c s t a t i c v o i d main ( f i n a l S t r i n g a r g v [ ] ) { 3 I n t e g e r i = new I n t e g e r ( " 4567 " ) ; 4 i n t j = i. i n t V a l u e ( ) ; 5 i = 4 5 6 7 ; // b o x i n g i = new I n t e g e r ( 4 5 6 7 ) ; 6 j = i / 2 ; // unboxing i. i n t V a l u e ( ) 7 System. out. p r i n t l n ( " I n t e g e r i : " + i + " i n t j : " + j + " \n " ) ; 8 j = I n t e g e r. p a r s e I n t ( " 123 " ) ; 9 System. out. p r i n t l n ( " j : " + j + " \n " ) ; 10 } 11 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 104/169

6 API Java 6.4 java.lang.* 6.4.2 Classe String Gestion des chaînes de caractères Un objet de type String n est pas modifiable Les constantes littérales comme abc sont converties en String L opérateur «+» permet la concaténation des String Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 105/169

6 API Java 6.4 java.lang.* 1 import j a v a. u t i l. Date ; 2 p u b l i c c l a s s S t r i n g E x a m p l e { 6.4.3 Exemple pour String 3 p u b l i c s t a t i c v o i d main ( f i n a l S t r i n g a r g v [ ] ) { 4 S t r i n g s = " \ u 0 0 c a t r e ou ne pas \ u 0 0 e a t r e " ; 5 i n t l g = s. l e n g t h ( ) ; 6 System. out. p r i n t l n ( s + " " + l g ) ; 7 System. out. p r i n t l n ( " Java ". s u b s t r i n g ( 2, 3 ) ) ; 8 System. out. p r i n t l n ( " Java " + " S o f t " ) ; 9 char [ ] data = { J, a, v, a } ; 10 S t r i n g n = new S t r i n g ( data ) ; System. out. p r i n t l n ( n ) ; 11 S t r i n g p = S t r i n g. v a l u e O f ( Math. PI ) ; System. out. p r i n t l n ( p ) ; 12 S t r i n g d = S t r i n g. v a l u e O f ( new Date ( ) ) ; System. out. p r i n t l n ( d ) ; 13 } 14 } Résultat de l exécution : Être ou ne pas être 19 v JavaSoft Java 3.141592653589793 Wed Sep 22 12:25:04 CEST 2010 Java Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 106/169

Introduction au langage de programmation Java Questions API java.lang 6 API Java Pourquoi faire dériver toutes les classes de java.lang.object? Pourquoi cette classe fournit-elle les méthodes suivantes : 1. tostring 2. equals La classe integer est finale, à votre avis pourquoi? (hors cours) Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 107/169

Introduction au langage de programmation Java 6 API Java 6.5 java.util.* java.lang java.util java.io <<Interface>> Cloneable BitSet Calendar <<Interface>> Serializable Object Currency Date Locale Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 108/169

6 API Java 6.5 java.util.* 6.5.1 Classe paramétrée ListeDeChoses E Paramètre de type élément : E taille : Integer premierélément : E dernierélément : E Attribut générique ajouter(e) estprésent(e) retirer(e) Opération générique Comme en UML, classe associée à la classe des objets qu elles servent à manipuler Classe associée spécifiée entre «<>» Exemple : Vector<String> mystringvector = new Vector<String>(); Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 109/169

6 API Java 6.5 java.util.* 6.5.2 Classes Abstraites des collections <<Interface>> java.lang.iterable <<Interface>> Collection<E> java.util <<Interface>> Enumeration<E> <<Interface>> Iterator<E> <<Interface>> Map<K,V> <<Interface>> List<E> <<Interface>> Set<E> <<Abstract>> AbstractMap<K,V> <<Abstract>> AbstractList<E> <<Abstract>> AbstractCollection<E> <<Abstract>> Dictionary<K,V> <<Abstract>> AbstractSet<E> java.lang.object Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 110/169

6 API Java 6.5 java.util.* 6.5.3 Classes instanciables des collections <<Interface>> java.lang.iterable <<Interface>> Collection<E> java.util <<Interface>> Enumeration<E> <<Interface>> Iterator<E> <<Interface>> Map<K,V> <<Interface>> List<E> <<Interface>> Set<E> <<Abstract>> AbstractMap<K,V> <<Abstract>> AbstractList<E> <<Abstract>> AbstractCollection<E> <<Abstract>> Dictionary<K,V> <<Abstract>> AbstractSet<E> Vector<E> HashMap<K,V> Hashtable<K,V> Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 111/169

6 API Java 6.5 java.util.* 6.5.4 Collections Collection : interface commune à toutes les collections ; List : interface permettant de gérer une liste ; Iterator : interface permettant de parcourir une collection ; Vector : réalisation de liste dans une sorte de tableau à taille variable ; Map : interface permettant de gérer des tables associant une clé à un objet ; Hashtable : tableau associatif Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 112/169

6 API Java 6.5 java.util.* 6.5.5 Interface Iterable provient de java.lang Préconise : Iterator<T> iterator() Iterator<> décrit 121 Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 113/169

6 API Java 6.5 java.util.* 6.5.6 Interface Collection<E> Collection la plus générale Insertion à la fin avec boolean add(e ) Suppression de tous les éléments avec void clear() Test de la présence d un objet dans la collection avec boolean contains(e) Test permettant de savoir si la collection est vide avec boolean isempty() Suppression du premier élément égal selon equals(e) au paramètre avec boolean remove(e) Nombre d éléments dans la collection avec int size(). Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 114/169

6 API Java 6.5 java.util.* 6.5.7 Interface List<E> Collection ordonnée supportant les objets dupliqués Accès à un élément avec E get(int index ) Insertion à une position donnée avec add(int, E) Suppression de l élément à une position donnée avec E remove(int)) Recherche de l indice d un objet s il est dans le vecteur avec int indexof(e) Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 115/169

6 API Java 6.5 java.util.* 6.5.8 Classe Vector<E> Gestion d une collection d éléments de la classe E dans un tableau dynamique Pas de contrainte d unicité sur les éléments Dérive de la classe AbstractList donc implémente l interface List donc implémente l interface Collection donc implémente aussi l interface Iterable. Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 116/169

6 API Java 6.5 java.util.* 6.5.9 Boucle pour les collections Simplification de l écriture des parcours de collections à partir de Java 5. Utilisation du for avec une collection, un tableau Syntaxe : for(type t : collection) Itère les objets de la collection dans la référence t Type de collection et type de t compatibles Ressemble aux foreach de php Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 117/169

6 API Java 6.5 java.util.* 6.5.10 Exemple for-each sur un Vector 1 import j a v a. u t i l. L i s t ; 2 import j a v a. u t i l. V e c t o r ; 3 p u b l i c c l a s s VectorForExample { 4 p u b l i c s t a t i c v o i d main ( S t r i n g a r g v [ ] ) { 5 L i s t <S t r i n g > v = new Vector <S t r i n g >(); 6 v. add ( " John " ) ; v. add ( " Georges " ) ; 7 System. out. p r i n t l n ( " T a i l l e de l a l i s t e " + v. s i z e ( ) ) ; 8 f o r ( S t r i n g s : v ){ 9 System. out. p r i n t l n ( " "+s ) ; 10 } 11 } 12 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 118/169

6 API Java 6.5 java.util.* 6.5.11 Exemple de classe avec Vector 1 import j a v a. u t i l. V e c t o r ; 2 import j a v a. u t i l. L i s t ; 3 p u b l i c c l a s s V e c t o r E x a m p l e B i s { 4 p u b l i c s t a t i c v o i d main ( S t r i n g a r g v [ ] ) { 5 L i s t <S t r i n g > v=new Vector <S t r i n g >(); 6 v. add ( " un " ) ; v. add ( " deux " ) ; v. add ( 2, " t r o i s " ) ; 7 System. out. p r i n t l n ( " Contenu du v e c t e u r : " ) ; 8 f o r ( i n t i =0; i <v. s i z e ( ) ; i ++) { 9 System. out. p r i n t l n ( " " + v. g e t ( i ) ) ; 10 } 11 i f ( v. remove ( " un " ) ) System. out. p r i n t l n ( " un removed " ) ; 12 v. remove ( 0 ) ; 13 System. out. p r i n t l n ( " Contenu du v e c t e u r : " ) ; 14 f o r ( i n t i =0; i <v. s i z e ( ) ; i ++) { 15 System. out. p r i n t l n ( " " + v. g e t ( i ) ) ; 16 } 17 } 18 } Trace de l exécution : Contenu du vecteur : Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 119/169

6 API Java 6.5 java.util.* un deux trois un removed Contenu du vecteur : trois Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 120/169

6 API Java 6.5 java.util.* 6.5.12 Interface Iterator Il s agit d une interface qui fournit une technique pour parcourir les éléments d une collection Iterator est spécialisé dans le parcours séquentiel des éléments d une collection. Il propose les méthodes suivantes : hasnext() retourne vrai si l itérateur contient encore une élément next() retourne l élément suivant remove() supprime le dernier élément retourné par next() de la collection toutes les collections possèdent la méthode iterator() Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 121/169

6 API Java 6.5 java.util.* 6.5.13 Exemple avec Iterator 1 import j a v a. u t i l. V e c t o r ; 2 import j a v a. u t i l. L i s t ; 3 import j a v a. u t i l. I t e r a t o r ; 4 p u b l i c c l a s s V e c t o r I t e r a t o r { 5 p u b l i c s t a t i c v o i d main ( S t r i n g a r g v [ ] ) { 6 L i s t <S t r i n g > v = new Vector <S t r i n g >(); 7 v. add ( " John " ) ; v. add ( " Georges " ) ; 8 I t e r a t o r <S t r i n g > e = v. i t e r a t o r ( ) ; 9 w h i l e ( e. hasnext ( ) ) { 10 System. out. p r i n t l n ( " " + e. n e x t ( ) ) ; 11 } 12 // P a r c o u r s avec une b o u c l e f o r 13 f o r ( e = v. i t e r a t o r ( ) ; e. hasnext ( ) ; ) { 14 System. out. p r i n t l n ( " " + e. n e x t ( ) ) ; 15 } 16 } 17 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 122/169

6 API Java 6.5 java.util.* 6.5.14 Dictionnaires Map<K,V> Les tables de correspondance permettent, à partir d une clé, de retrouver une valeur Cette interface est associée à deux paramètres qui correspondent à la classe de la clé et à celle de la valeur C est pourquoi sa définition est notée Map<K,V> Par exemple, Map<String,String> mymap Map supporte les méthodes supplémentaires suivantes, en plus de celles prescrites par Collection : boolean containskey(k key) boolean containsvalue(v value) Set<K> keysset() Collection<V> values() V get(k key) V put(k key, V value) Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 123/169

6 API Java 6.5 java.util.* 6.5.15 Exemple pour Map 1 import j a v a. u t i l. H a s h t a b l e ; 2 import j a v a. u t i l. Map ; 3 p u b l i c c l a s s HashMapExample{ 4 p u b l i c s t a t i c v o i d main ( f i n a l S t r i n g a r g v [ ] ) { 5 Map<S t r i n g, S t r i n g > ht = new Hashtable <S t r i n g, S t r i n g >(); 6 ht. put ( "Ba", "Bah" ) ; ht. put ( "Aa", " aha " ) ; 7 ht. put ( "BB", " bebe " ) ; 8 f o r ( S t r i n g k : ht. k e y S e t ( ) ) { 9 System. out. p r i n t l n ( " C l e : "+ k 10 + " V a l e u r : " + ht. g e t ( k ) ) ; 11 } 12 f o r ( S t r i n g v : ht. v a l u e s ( ) ) { 13 System. out. p r i n t l n ( " V a l e u r : " + v ) ; 14 } 15 } 16 } Le résultat de l exécution de l exemple est le suivant : Cle : Ba Valeur : Bah Cle : BB Valeur : bebe Cle : Aa Valeur : aha Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 124/169

6 API Java 6.5 java.util.* Valeur : Bah Valeur : bebe Valeur : aha Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 125/169

6 API Java 6.5 java.util.* 6.5.16 Dictionnaire Hashtable<K,V> Ces dictionnaires réalisent l interface Map. La classe associée à la clé doit supporter les méthodes hashcode() et equals() Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 126/169

6 API Java 6.5 java.util.* 6.5.17 Exemple pour Hashtable 1 import j a v a. u t i l. H a s h t a b l e ; 2 import j a v a. u t i l. I t e r a t o r ; 3 import j a v a. u t i l. Map ; 4 p u b l i c c l a s s HashtableExample { 5 p u b l i c s t a t i c v o i d main ( f i n a l S t r i n g a r g v [ ] ) { 6 Map<S t r i n g, S t r i n g > ht = new Hashtable <S t r i n g, S t r i n g >(); 7 ht. put ( "Ba", "Bah" ) ; ht. put ( "Aa", " aha " ) ; 8 ht. put ( "BB", " bebe " ) ; 9 f o r ( S t r i n g k : ht. k e y S e t ( ) ) { 10 System. out. p r i n t l n ( " C l e : "+ k + " Hash : "+ k. hashcode ( ) 11 + " V a l e u r : " + ht. g e t ( k ) ) ; 12 } 13 } 14 } Le résultat de l exécution de l exemple est le suivant : Cle : Ba Hash : 2143 Valeur : Bah Cle : BB Hash : 2112 Valeur : bebe Cle : Aa Hash : 2112 Valeur : aha Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 127/169

6 API Java 6.5 java.util.* 6.5.18 Représentation d une Hashtable BB Aa 2112 000 111 000 111 000 111 11 Bebe Aha Ba 2143 Bah Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 128/169

Introduction au langage de programmation Java Questions collections en Java 6 API Java Quelles sont les opérations préconisées par l interface Collection? À quel usage est destiné un Iterator? Quelle est l utilité du concept de Map? Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 129/169

Introduction au langage de programmation Java 7 Exceptions en Java 7.1 Motivation : retours sur un bug.............................................. 131 7.2 Principes................................................................... 132 7.3 Réalisation..................................................................135 7.4 Traitement des exceptions................................................... 138 7.5 Exemple de traitement d exceptions.......................................... 139 Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 130/169

Introduction au langage de programmation Java 7 Exceptions en Java 7.1 Motivation : retours sur un bug Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 131/169

Introduction au langage de programmation Java 7.2 Principes 7 Exceptions en Java Séparation entre flot de gestion des erreurs et flot d exécution normale Contrôle de flot spécifique pour les exceptions Parties de code balisées relativement au traitement d erreurs (régions gardées) Parties de code spécifiques pour le traitement d erreurs Méthode constatant l erreur et ne possédant pas suffisamment d informations dans son contexte pour la traiter Nécessité de remonter le chemin d appel jusqu à trouver une méthode possédant suffisamment d informations pour traiter cette erreur Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 132/169

7 Exceptions en Java 7.2 Principes 7.2.1 Mise en œuvre Les méthodes peuvent : Lever une exception : En prévenant les autres méthodes par l ajout d une clause throws dans leur prototype En créant un objet du type exception : classe qui dérive de java.lang.exception Et en utilisant le mot réservé «throw» pour provoquer la remontée du chemin d appel Relayer des exceptions en ajoutant au prototype le mot clef «throws» et la liste des exceptions Traiter des exceptions par des blocs try, catch, et finally Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 133/169

7 Exceptions en Java 7.2 Principes 7.2.2 Exemple de traitement 1 p u b l i c c l a s s A r r a y C o n t r o l e d { 2 s t a t i c f i n a l i n t max = 4 2 ; 3 p u b l i c s t a t i c v o i d main ( S t r i n g [ ] a r g s ) { 4 i n t i, j = 0 ; 5 i n t [ ] a r r a y O f I n t = new i n t [ max ] ; 6 f o r ( i =0; i <a r r a y O f I n t. l e n g t h ; i ++){ 7 a r r a y O f I n t [ i ] = i ; 8 } 9 f o r ( i =0; i <a r g s. l e n g t h ; i ++){ 10 t r y { 11 j = I n t e g e r. p a r s e I n t ( a r g s [ i ] ) ; 12 System. out. p r i n t l n ( a r r a y O f I n t [ j ] ) ; 13 } catch ( NumberFormatException n f e ){ 14 System. out. p r i n t l n ( " Parameter " + a r g s [ i ] + " s h o u l d be an i n t e g e r " ) ; 15 } catch ( ArrayIndexOutOfBoundsException oobe ){ 16 System. out. p r i n t l n ( " Parameter " + a r g s [ i ] 17 + " s h o u l d be >=0 and <" + max ) ; 18 } 19 } 20 } 21 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 134/169

Introduction au langage de programmation Java 7 Exceptions en Java 7.3 Réalisation Classes dérivées de java.lang.exception Lever une exception consiste à : Créer une instance d une classe dérivée de java.lang.exception Déclencher le déroulement arrière des appels de méthodes qui ont menés à la méthode courante Arrêt du déroulement arrière à la rencontre un bloc try catch pour ce type d exception S il n y a aucun bloc try l exception remonte jusqu à la machine virtuelle Java qui interrompt l exécution Lorsqu un bloc try catch correspondant à l exception est trouvé : les instructions suivantes du bloc try sont sautées les instructions du bloc catch qui correspond le mieux sont exécutées Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 135/169

7 Exceptions en Java 7.3 Réalisation Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 136/169

7 Exceptions en Java 7.3 Réalisation 7.3.1 java.lang.exception Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 137/169

Introduction au langage de programmation Java 7.4 Traitement des exceptions 7 Exceptions en Java Pour les exceptions sous contrôle : Une méthode qui fait appel à une méthode qui peut lever une exception doit définir son comportement relativement à cette exception Traiter l exception par un bloc try catch Relayer l exception par le mot réservé throws Réorganisation du code de manière cohérente dans les blocs try. Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 138/169

Introduction au langage de programmation Java 7 Exceptions en Java 7.5 Exemple de traitement d exceptions 1 p u b l i c c l a s s NumException extends E x c e p t i o n { 2 p r i v a t e s t a t i c f i n a l l o n g s e r i a l V e r s i o n U I D = 1L ; 3 p u b l i c NumException ( f i n a l double v a l e u r, f i n a l S t r i n g s ) { 4 s u p e r ( s + " v a l e u r : " + v a l e u r ) ; 5 } 6 } 1 p u b l i c c l a s s T e s t S i m p l e E x c e p t { 2 / 3 P o s i t i f t e s t e s i l a v a l e u r du p a r a m e t r e v a l e s t p o s i t i v e. 4 @param v a l v a l e u r a t e s t e r 5 @throws NumException s i v a l e s t < 0 6 / 7 p r i v a t e s t a t i c v o i d p o s i t i f ( f i n a l double v a l ) throws NumException { 8 i f ( v a l < 0. 0 ) throw new NumException ( v a l, " V a l e u r p o s i t i v e a t t e n d u e. " ) ; 9 r e t u r n ; 10 } 11 / 12 t e s t P o s i t i f u t i l i s e p o s i t i f e t r e l a y e l e x c e p t i o n NumException. 13 @param v a l v a l e u r a t e s t e r. 14 @throws NumException l o r s q u e p o s i t i f emet NumException 15 / Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 139/169

Introduction au langage de programmation Java 7 Exceptions en Java 16 p r i v a t e s t a t i c v o i d t e s t P o s i t i f ( double v a l ) throws NumException { 17 p o s i t i f ( v a l ) ; 18 System. out. p r i n t l n ( " Pas d e x c e p t i o n l e code c o n t i n u e en s e q u e n c e " ) ; 19 r e t u r n ; 20 } 21 / 22 T r a i t e m e n t des arguments de main par t e s t des 23 v a l e u r s e n t i e r e s p o s i t i v e s. 24 @param a r g v arguments de l a l i g n e de commande. 25 / 26 p u b l i c s t a t i c v o i d main ( f i n a l S t r i n g [ ] a r g v ) { 27 i n t i, j = 0 ; 28 f o r ( i =0; i <a r g v. l e n g t h ; i ++) { 29 t r y { 30 j = I n t e g e r. p a r s e I n t ( a r g v [ i ] ) ; 31 t e s t P o s i t i f ( j ) ; 32 } catch ( NumberFormatException n f e ){ 33 System. out. p r i n t l n ( " Parameter " + a r g v [ i ] + " s h o u l d be an i n t e g e r " ) ; 34 } catch ( NumException n ){ 35 System. out. p r i n t l n ( " Catch dans l e main " + n ) ; 36 } 37 } 38 } 39 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 140/169

Introduction au langage de programmation Java 7 Exceptions en Java Trace d exécution avec arguments 2, -3 et 3 : Pas d exception le code continue en sequence Catch dans le main NumException: Valeur positive attendue. valeur : -3.0 Pas d exception le code continue en sequence Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 141/169

Introduction au langage de programmation Java Questions sur les exceptions 7 Exceptions en Java À quoi servent : 1. Le bloc try catch? 2. Le mot réservé new après la directive throw? Pourquoi créer une classe d exception? Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 142/169

Introduction au langage de programmation Java 8 Concepts objets avancés en Java 8.1 Copie simple/légère......................................................... 144 8.2 Retour sur hashcode()..................................................... 161 8.3 Retour sur les exceptions.................................................... 163 Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 143/169

Introduction au langage de programmation Java 8 Concepts objets avancés en Java 8.1 Copie simple/légère Les objets sont manipulés par des références o2 = o1 : copie la référence o1 dans o2 obj1 o1 "Jean" o1 obj1 "Jean" o2 "Paul" obj2 o2 "Paul" obj2 o2 = o1.clone() : o2 référence un nouvel objet (copie de o1) o1 "Jean" o1 "Jean" o2 "Paul" o2 "Paul" "Jean" Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 144/169

8 Concepts objets avancés en Java 8.1 Copie simple/légère 8.1.1 Copie pour studs * Personne nbtotalparticipations nbtotalorganisations nbparticipations nborganisations prenom nom concerne concerne organise * * Scrutin intituléscrutin textecommentairescrutin datecréation datedébut datelimite datelimiteexistence ouvertureavancée fermetureavancée destructionavancée nbtotalscrutin /nbchoix ScrutinPlagesHoraires nbtotal ScrutinPréférences nbtotal * * * Bulletin pouroucontre * PlageHoraire date heuredébut heurefin * Préférence intitulépréférence textecommentairepréf Studs * concerne * Choix /nbbulletinspour /nbbulletinscontre Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 145/169

8 Concepts objets avancés en Java 8.1 Copie simple/légère 8.1.2 Représentation graphique d une copie légère dans studs p: p1: :Personne nom prénom scrutins :Personne nom prénom scrutins :String = "Dupont" :String = "Julien" :ArrayList :Scrutin :String nom organisateur = "Election bde" Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 146/169

8 Concepts objets avancés en Java 8.1 Copie simple/légère 8.1.3 Exemple de copie légère 1 package s t u d s c l o n e l i g h t ; 2 import j a v a. u t i l. A r r a y L i s t ; 3 import s t u d s. B u l l e t i n ; 4 p u b l i c c l a s s Personne implements C l o n e a b l e { 5 p r i v a t e S t r i n g nom, prenom ; 6 p r i v a t e i n t n b P a r t i c i p a t i o n s = 0, nborg = 0 ; 7 p r i v a t e A r r a y L i s t <S c r u t i n > s c r u t i n s ; 8 p u b l i c Personne ( S t r i n g nom, S t r i n g prenom ){ 9 t h i s. nom = nom ; t h i s. prenom = prenom ; s c r u t i n s = new A r r a y L i s t <S c r u t i n >(); } 10 p u b l i c S c r u t i n o r g a n i s e r S c r u t i n ( S t r i n g nom) { 11 s c r u t i n s. add ( new S c r u t i n (nom, t h i s ) ) ; r e t u r n s c r u t i n s. g e t ( nborg++); } 12 @ O v e r r i d e 13 p u b l i c Personne c l o n e ( ) throws C l o n e N o t S u p p o r t e d E x c e p t i o n { 14 r e t u r n ( Personne ) s u p e r. c l o n e ( ) ; 15 } 16 p u b l i c S t r i n g getnom ( ) { r e t u r n nom ; } 17 p u b l i c S t r i n g getprenom ( ) { r e t u r n prenom ; } 18 p u b l i c A r r a y L i s t <S c r u t i n > g e t S c r u t i n s ( ) { r e t u r n s c r u t i n s ; } 19 p u b l i c v o i d v o t e r ( B u l l e t i n b ){ } 20 p u b l i c v o i d c o n s u l t e r R e s u l t a t ( S c r u t i n s ) { } 21 p u b l i c v o i d s e R e t i r e r D U n S c r u t i n ( S c r u t i n s ) { } 22 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 147/169

8 Concepts objets avancés en Java 8.1 Copie simple/légère 1 import j a v a. u t i l. A r r a y L i s t ; 2 import s t u d s c l o n e l i g h t. S c r u t i n ; 3 import s t u d s c l o n e l i g h t. Personne ; 4 p u b l i c c l a s s T e s t C l o n e L i g h t { 5 p u b l i c s t a t i c v o i d main ( f i n a l S t r i n g [ ] a r g s ) 6 throws C l o n e N o t S u p p o r t e d E x c e p t i o n { 7 Personne p = new Personne ( " Dupont ", " J u l i e n " ) ; 8 p. o r g a n i s e r S c r u t i n ( " E l e c t i o n bde " ) ; 9 Personne p1 = p. c l o n e ( ) ; 10 i f ( p1 == p ) { 11 System. out. p r i n t l n ( " p == p1 " ) ; 12 } 13 i f ( p. getnom ( ) == p1. getnom ( ) ) { 14 System. out. p r i n t l n ( " p e t p1 noms ==" ) ; 15 } 16 i f ( p. getprenom ( ) == p1. getprenom ( ) ) { 17 System. out. p r i n t l n ( " p e t p1 prenoms ==" ) ; 18 } 19 A r r a y L i s t <S c r u t i n > a1, a2 ; 20 a1 = p. g e t S c r u t i n s ( ) ; 21 a2 = p1. g e t S c r u t i n s ( ) ; 22 i f ( a1 == a2 ) { 23 System. out. p r i n t l n ( " p e t p1 s c r u t i n s ==" ) ; 24 } e l s e { Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 148/169

8 Concepts objets avancés en Java 8.1 Copie simple/légère 25 f o r ( i n t i = 0 ; i < a1. s i z e ( ) ; i ++){ 26 i f ( a1. g e t ( i ) == a2. g e t ( i ) ) { 27 System. out. p r i n t l n ( " S c r u t i n de rang " + i +" ==" ) ; 28 } 29 } 30 } 31 } 32 } p et p1 noms == p et p1 prenoms == p et p1 scrutins == Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 149/169

8 Concepts objets avancés en Java 8.1 Copie simple/légère 8.1.4 Représentation graphique d une copie plus profonde dans studs p: p1: :Personne :Personne nom prénom scrutins nom prénom scrutins :String :ArrayList :ArrayList :String = "Dupont" = "Dupont" :String = "Julien" :String = "Julien" :Scrutin nom organisateur :String = "Election bde" Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 150/169

8 Concepts objets avancés en Java 8.1 Copie simple/légère 1 package s t u d s c l o n e d e e p ; 2 import j a v a. u t i l. A r r a y L i s t ; 3 8.1.5 Copie plus profonde dans studs 4 import s t u d s. B u l l e t i n ; 5 p u b l i c c l a s s Personne implements C l o n e a b l e { 6 p r i v a t e S t r i n g nom, prenom ; 7 p r i v a t e i n t n b P a r t i c i p a t i o n s = 0, nborg = 0 ; 8 p r i v a t e A r r a y L i s t <S c r u t i n > s c r u t i n s ; 9 p u b l i c Personne ( f i n a l S t r i n g n, f i n a l S t r i n g p ) { 10 t h i s. nom = n ; 11 t h i s. prenom = p ; 12 s c r u t i n s = new A r r a y L i s t <S c r u t i n >(); 13 } 14 p u b l i c S c r u t i n o r g a n i s e r S c r u t i n ( f i n a l S t r i n g nom) { 15 S c r u t i n s = new S c r u t i n (nom, t h i s ) ; 16 s c r u t i n s. add ( s ) ; 17 nborg ++; 18 r e t u r n s ; 19 } 20 / l e c l o n a g e e s t profond, i l d u p l i q u e l e s o b j e t s r e f e r e n c e s / 21 @SuppressWarnings ( " unchecked " ) 22 @ O v e r r i d e Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 151/169

8 Concepts objets avancés en Java 8.1 Copie simple/légère 23 p u b l i c Personne c l o n e ( ) throws C l o n e N o t S u p p o r t e d E x c e p t i o n { 24 Personne c l o n e = new Personne ( new S t r i n g (nom ), new S t r i n g ( prenom ) ) ; 25 c l o n e. n b P a r t i c i p a t i o n s = n b P a r t i c i p a t i o n s ; 26 c l o n e. nborg = nborg ; 27 c l o n e. s c r u t i n s = ( A r r a y L i s t <S c r u t i n >) s c r u t i n s. c l o n e ( ) ; 28 r e t u r n c l o n e ; 29 } 30 p u b l i c S t r i n g getnom ( ) { r e t u r n nom ; } 31 p u b l i c S t r i n g getprenom ( ) { r e t u r n prenom ; } 32 p u b l i c A r r a y L i s t <S c r u t i n > g e t S c r u t i n s ( ) { r e t u r n s c r u t i n s ; } 33 p u b l i c v o i d v o t e r ( f i n a l B u l l e t i n b ){ } 34 p u b l i c v o i d c o n s u l t e r R e s u l t a t ( S c r u t i n s ) { } 35 p u b l i c v o i d s e R e t i r e r D U n S c r u t i n ( S c r u t i n s ) { } 36 } 1 import j a v a. u t i l. A r r a y L i s t ; 2 3 import s t u d s c l o n e d e e p. S c r u t i n ; 4 import s t u d s c l o n e d e e p. Personne ; 5 p u b l i c c l a s s TestCloneDeep { 6 p u b l i c s t a t i c v o i d main ( f i n a l S t r i n g [ ] a r g s ) 7 throws C l o n e N o t S u p p o r t e d E x c e p t i o n { 8 Personne p = new Personne ( " Dupont ", " J u l i e n " ) ; 9 p. o r g a n i s e r S c r u t i n ( " E l e c t i o n bde " ) ; Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 152/169

8 Concepts objets avancés en Java 8.1 Copie simple/légère 10 Personne p1 = p. c l o n e ( ) ; 11 i f ( p1 == p ) { 12 System. out. p r i n t l n ( " p == p1 " ) ; 13 } 14 i f ( p. getnom ( ) == p1. getnom ( ) ) { 15 System. out. p r i n t l n ( " p e t p1 noms ==" ) ; 16 } 17 i f ( p. getprenom ( ) == p1. getprenom ( ) ) { 18 System. out. p r i n t l n ( " p e t p1 prenoms ==" ) ; 19 } 20 A r r a y L i s t <S c r u t i n > a1, a2 ; 21 a1 = p. g e t S c r u t i n s ( ) ; 22 a2 = p1. g e t S c r u t i n s ( ) ; 23 i f ( a1 == a2 ) { 24 System. out. p r i n t l n ( " p e t p1 s c r u t i n s ==" ) ; 25 } e l s e { 26 f o r ( i n t i = 0 ; i < a1. s i z e ( ) ; i ++) { 27 i f ( a1. g e t ( i ) == a2. g e t ( i ) ) { 28 System. out. p r i n t l n ( " S c r u t i n s de rang " + i +" ==" ) ; 29 } e l s e { 30 i f ( a1. g e t ( i ). g e t O r g a n i s a t e u r ( ) == a2. g e t ( i ). g e t O r g a n i s a t e u r ( ) ) { 31 System. out. p r i n t l n ( " O r a g a n i s a t e u r des s c r u t i n s de rang " + i +"= 32 } 33 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 153/169

8 Concepts objets avancés en Java 8.1 Copie simple/légère 34 } 35 } 36 } 37 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 154/169

8 Concepts objets avancés en Java 8.1 Copie simple/légère 8.1.6 Représentation graphique d une copie profonde p: p1: :Personne :Personne nom prénom scrutins nom prénom scrutins :String :ArrayList :ArrayList :String = "Dupont" = "Dupont" :String = "Julien" :String = "Julien" :Scrutin nom organisateur :String = "Election bde" :Scrutin nom organisateur :String = "Election bde" Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 155/169

8 Concepts objets avancés en Java 8.1 Copie simple/légère 8.1.7 Clone de Scrutin 1 package s t u d s c l o n e ; 2 p u b l i c c l a s s S c r u t i n implements C l o n e a b l e { 3 p r i v a t e Personne o r g a n i s a t e u r ; 4 p r i v a t e S t r i n g nomscrutin ; 5 p u b l i c S c r u t i n ( f i n a l S t r i n g nom, f i n a l Personne o r g a n i s a t e u r ) { 6 nomscrutin = nom ; 7 t h i s. o r g a n i s a t e u r = o r g a n i s a t e u r ; 8 } 9 / l e c l o n a g e d u p l i q u e l e nom mais ne peut pas m o d i f i e r l o r g a n i s a t e u r. / 10 @ O v e r r i d e 11 p u b l i c S c r u t i n c l o n e ( ) throws C l o n e N o t S u p p o r t e d E x c e p t i o n { 12 r e t u r n new S c r u t i n ( new S t r i n g ( nomscrutin ), o r g a n i s a t e u r ) ; 13 } 14 / Methode pour m o d i f i e r l o r g a n i s a t e u r en c a s de c l o n a g e. / 15 v o i d s e t O r g a n i s a t e u r ( f i n a l Personne norg ) { 16 o r g a n i s a t e u r = norg ; 17 } 18 p u b l i c Personne g e t O r g a n i s a t e u r ( ) { 19 r e t u r n o r g a n i s a t e u r ; 20 } 21 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 156/169

8 Concepts objets avancés en Java 8.1 Copie simple/légère 8.1.8 Clone en copie profonde de Personne 1 package s t u d s c l o n e ; 2 import j a v a. u t i l. A r r a y L i s t ; 3 import s t u d s a b s t r a c t. B u l l e t i n ; 4 p u b l i c c l a s s Personne implements C l o n e a b l e { 5 p r i v a t e S t r i n g nom, prenom ; 6 p r i v a t e i n t n b P a r t i c i p a t i o n s = 0, nborg = 0 ; 7 p r i v a t e A r r a y L i s t <S c r u t i n > s c r u t i n s ; 8 p u b l i c Personne ( f i n a l S t r i n g n, f i n a l S t r i n g p ) { 9 t h i s. nom = n ; 10 t h i s. prenom = p ; 11 s c r u t i n s = new A r r a y L i s t <S c r u t i n >(); 12 } 13 p u b l i c S c r u t i n o r g a n i s e r S c r u t i n ( f i n a l S t r i n g nom) { 14 S c r u t i n s = new S c r u t i n (nom, t h i s ) ; 15 s c r u t i n s. add ( s ) ; 16 nborg ++; 17 r e t u r n s ; 18 } 19 / l e c l o n a g e e s t profond, i l d u p l i q u e l e s o b j e t s r e f e r e n c e s. / 20 @ O v e r r i d e 21 p u b l i c Personne c l o n e ( ) throws C l o n e N o t S u p p o r t e d E x c e p t i o n { 22 Personne c l = new Personne ( new S t r i n g (nom ), new S t r i n g ( prenom ) ) ; Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 157/169

8 Concepts objets avancés en Java 8.1 Copie simple/légère 23 c l. n b P a r t i c i p a t i o n s = n b P a r t i c i p a t i o n s ; 24 c l. nborg = nborg ; 25 f o r ( S c r u t i n s c r : s c r u t i n s ) { 26 S c r u t i n s c l o n e = s c r. c l o n e ( ) ; 27 s c l o n e. s e t O r g a n i s a t e u r ( c l ) ; 28 c l. s c r u t i n s. add ( s c l o n e ) ; 29 } 30 r e t u r n c l ; 31 } 32 p u b l i c S t r i n g getnom ( ) { r e t u r n nom ; } 33 p u b l i c S t r i n g getprenom ( ) { r e t u r n prenom ; } 34 p u b l i c A r r a y L i s t <S c r u t i n > g e t S c r u t i n s ( ) { r e t u r n s c r u t i n s ; } 35 p u b l i c v o i d v o t e r ( f i n a l B u l l e t i n b ){ } 36 p u b l i c v o i d c o n s u l t e r R e s u l t a t ( S c r u t i n s ) { } 37 p u b l i c v o i d s e R e t i r e r D U n S c r u t i n ( S c r u t i n s ) { } 38 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 158/169

8 Concepts objets avancés en Java 8.1 Copie simple/légère 1 import j a v a. u t i l. A r r a y L i s t ; 2 8.1.9 Suite exemple de copie profonde 3 import s t u d s c l o n e. ; 4 p u b l i c c l a s s TestClone { 5 p u b l i c s t a t i c v o i d main ( f i n a l S t r i n g [ ] a r g s ) 6 throws C l o n e N o t S u p p o r t e d E x c e p t i o n { 7 Personne p = new Personne ( " Dupont ", " J u l i e n " ) ; 8 p. o r g a n i s e r S c r u t i n ( " E l e c t i o n bde 2010 " ) ; 9 Personne p1 = p. c l o n e ( ) ; 10 i f ( p1 == p ) { 11 System. out. p r i n t l n ( " p == p1 " ) ; 12 } 13 i f ( p. getnom ( ) == p1. getnom ( ) ) { 14 System. out. p r i n t l n ( " p e t p1 noms ==" ) ; 15 } 16 i f ( p. getprenom ( ) == p1. getprenom ( ) ) { 17 System. out. p r i n t l n ( " p e t p1 prenoms ==" ) ; 18 } 19 A r r a y L i s t <S c r u t i n > a1, a2 ; 20 a1 = p. g e t S c r u t i n s ( ) ; 21 a2 = p1. g e t S c r u t i n s ( ) ; 22 i f ( a1 == a2 ) { Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 159/169

8 Concepts objets avancés en Java 8.1 Copie simple/légère 23 System. out. p r i n t l n ( " p e t p1 s c r u t i n s ==" ) ; 24 } e l s e { 25 f o r ( i n t i = 0 ; i < a1. s i z e ( ) ; i ++) { 26 i f ( a1. g e t ( i ) == a2. g e t ( i ) ) { 27 System. out. p r i n t l n ( " S c r u t i n s de rang " + i +" ==" ) ; 28 } e l s e { 29 i f ( a1. g e t ( i ). g e t O r g a n i s a t e u r ( ) == a2. g e t ( i ). g e t O r g a n i s a t e u r ( ) ) { 30 System. out. p r i n t l n ( " O r a g a n i s a t e u r des s c r u t i n s de rang " + i +"= 31 } 32 } 33 } 34 } 35 } 36 } Résultat de l exécution : Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 160/169

Introduction au langage de programmation Java 8.2 Retour sur hashcode() 8 Concepts objets avancés en Java Méthode facilitant l utilisation de Hashtable Contrat de base : Doit retourner la même valeur lorsqu elle est appelée plusieurs fois sur le même objet Doit retourner la même valeur pour deux objets equals Peut retourner la même valeur pour deux objets différents (limites du hachage) Algorithme de J. Bloch dans Effective Java Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 161/169

8 Concepts objets avancés en Java 8.2 Retour sur hashcode() 8.2.1 Exemple hashcode 1 package s t u d s e q u a l s ; 2 p u b l i c c l a s s Personne { 3 p r i v a t e S t r i n g nom, prenom ; 4 p u b l i c Personne ( f i n a l S t r i n g nom, f i n a l S t r i n g prenom ){ 5 t h i s. nom = nom ; t h i s. prenom = prenom ; 6 } 7 @ O v e r r i d e 8 p u b l i c boolean e q u a l s ( O b j e c t o b j ) { 9 i f ( t h i s == o b j ) r e t u r n t r u e ; 10 i f ( o b j == n u l l ) r e t u r n f a l s e ; 11 i f (! ( o b j i n s t a n c e o f Personne ) ) r e t u r n f a l s e ; 12 Personne o t h e r = ( Personne ) o b j ; 13 i f (nom == n u l l ) { 14 i f ( o t h e r. nom!= n u l l ) r e t u r n f a l s e ; 15 } e l s e i f (! nom. e q u a l s ( o t h e r. nom ) ) r e t u r n f a l s e ; 16 i f ( prenom == n u l l ) { 17 i f ( o t h e r. prenom!= n u l l ) r e t u r n f a l s e ; 18 } e l s e i f (! prenom. e q u a l s ( o t h e r. prenom ) ) r e t u r n f a l s e ; 19 r e t u r n t r u e ; 20 } 21 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 162/169

Introduction au langage de programmation Java 8 Concepts objets avancés en Java 8.3 Retour sur les exceptions 1 p u b l i c c l a s s NumException extends E x c e p t i o n { 2 p r i v a t e s t a t i c f i n a l l o n g s e r i a l V e r s i o n U I D = 1L ; 3 p u b l i c NumException ( f i n a l double v a l e u r, f i n a l S t r i n g s ) { 4 s u p e r ( s + " v a l e u r : " + v a l e u r ) ; 5 } 6 } 1 p u b l i c c l a s s N u l l E x c e p t i o n extends NumException { 2 p r i v a t e s t a t i c f i n a l l o n g s e r i a l V e r s i o n U I D = 1L ; 3 p u b l i c N u l l E x c e p t i o n ( ) { 4 s u p e r ( 0, " V a l e u r n u l l e non a t t e n d u e " ) ; 5 } 6 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 163/169

8 Concepts objets avancés en Java 8.3 Retour sur les exceptions 8.3.1 Test des exceptions 1 p u b l i c c l a s s T e s t E x c e p t I n H e r i t { 2 / 3 Methode v e r i f i a n t qu une v a l e u r e s t p o s i t i v e. 4 @param v a l v a l e u r a t e s t e r 5 @ r e t u r n v a l e u r d e n t r e e 6 @throws NumException s i v a l e u r n e g a t i v e 7 @throws N u l l E x c e p t i o n s i v a l e u r e g a l e a z e r o. 8 / 9 p r i v a t e s t a t i c double p o s i t i f O u N u l l ( f i n a l double v a l ) 10 throws NumException, N u l l E x c e p t i o n { 11 i f ( v a l < 0. 0 ) { 12 throw new NumException ( v a l, " P o s i t i f O u N u l l v a l e u r p o s i t i v e a t t e n d u e. " ) ; 13 } 14 i f ( v a l == 0. 0 ) { 15 throw new N u l l E x c e p t i o n ( ) ; 16 } 17 r e t u r n v a l ; 18 } 19 / 20 t r a i t e m e n t p a r t i e l d e x c e p t i o n l e s e x c e p t i o n s 21 N u l l E x c e p t i o n s o n t t r a i t e e s, l e s e x c e p t i o n s NumException 22 s o n t t r a i t e e s p a r t i e l l e m e n t e t r e l a y e e s. Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 164/169

8 Concepts objets avancés en Java 8.3 Retour sur les exceptions 23 @param v a l v a l e u r a t e s t e r 24 @throws NumException 25 / 26 p r i v a t e s t a t i c v o i d t e s t P o s i t i f O u N u l l ( f i n a l double v a l ) 27 throws NumException { 28 double d=0; 29 System. out. p r i n t l n ( " Dans t e s t P o s i t i f O u N u l l v a l = "+v a l ) ; 30 t r y { 31 d = p o s i t i f O u N u l l ( v a l ) ; 32 System. out. p r i n t l n ( " Pas d e x c e p t i o n l e code c o n t i n u e en s e q u e n c e " ) ; 33 } catch ( N u l l E x c e p t i o n m) { 34 System. out. p r i n t l n ( " Catch N u l l E x c e p t i o n dans t e s t P o s i t i f O u N u l l " + m) ; 35 throw m; 36 } catch ( NumException m) { 37 System. out. p r i n t l n ( " Catch NumException dans t e s t P o s i t i f O u N u l l " 38 + " t r a i t e m e n t p a r t i e l e t r e l a i s " + m) ; 39 throw m; 40 } 41 f i n a l l y { 42 System. out. p r i n t l n ( " Dans l e f i n a l l y de t e s t P o s i t i f O u N u l l " + d ) ; 43 } 44 } 45 p u b l i c s t a t i c v o i d main ( f i n a l S t r i n g [ ] a r g s ) { 46 i n t j = 0 ; Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 165/169

8 Concepts objets avancés en Java 8.3 Retour sur les exceptions 47 f o r ( S t r i n g onearg : a r g s ){ 48 t r y { 49 j = I n t e g e r. p a r s e I n t ( onearg ) ; 50 t e s t P o s i t i f O u N u l l ( j ) ; 51 } catch ( NumberFormatException n f e ){ 52 System. out. p r i n t l n ( " Parameter " + onearg 53 + " s h o u l d be an i n t e g e r " ) ; 54 } catch ( NumException n ){ 55 System. out. p r i n t l n ( " Catch dans l e main " + n ) ; 56 } 57 } 58 } 59 } Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 166/169

8 Concepts objets avancés en Java 8.3 Retour sur les exceptions L exécution de ce programme avec les arguments du main 2 0-2 donne l affichage suivant : Dans testpositifounull val = 2.0 Pas d exception le code continue en sequence Dans le finally de testpositifounull 2.0 Dans testpositifounull val = 0.0 Catch NullException dans testpositifounull NullException: Valeur nulle non attendue valeur reçue : 0.0 Dans le finally de testpositifounull 0.0 Catch dans le main NullException: Valeur nulle non attendue valeur reçue : 0.0 Dans testpositifounull val = -2.0 Catch NumException dans testpositifounull traitement partiel et relaisnumexception: PositifOuNull valeur positive attendue. valeur reçue : -2.0 Dans le finally de testpositifounull 0.0 Catch dans le main NumException: PositifOuNull valeur positive attendue. valeur reçue : -2.0 Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 167/169

8 Concepts objets avancés en Java 8.3 Retour sur les exceptions Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 168/169

8 Concepts objets avancés en Java 8.3 Retour sur les exceptions 8.3.2 RuntimeException Télécom SudParis Christian Bac, Denis Conan Octobre 2014 CSC 4002 169/169

Bibliographie