INFO-F-202 Langages II Java
|
|
- Stéphanie Boivin
- il y a 8 ans
- Total affichages :
Transcription
1 INFO-F-202 Langages II Vandy BERTEN Université Libre de Bruxelles Vandy BERTEN INFO-F-202 Université Libre de Bruxelles 1 / 109
2 Table des matières 1 Introduction 2 Les bases 3 et Orienté Objet 4 Threads 5 Mais encore... Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 2 / 109
3 Introduction Table des matières I 1 Introduction Motivations Historique Principes Premier exemple JVM 2 Les bases 3 et Orienté Objet 4 Threads 5 Mais encore... Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 3 / 109
4 Introduction Motivations Pourquoi? Syntaxiquement proche du C++ Mais beaucoup plus orienté objets plus propre! Pas de pointeurs (visibles), d accès direct à la mémoire plus sûr! Adapté à de nombreux environnements : applications, applets (web), cartes à puce, téléphones... Code compilé portable API très fournie, système de documentation natif Nombreux outils pour les systèmes distribués (RMI, sockets, Corba... ) Système de threads (multi-tâches) natif et élégant... Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 4 / 109
5 Introduction Motivations Objectifs Apprendre depuis C++ Approfondir sa connaissance du C++ (références, gestion de la mémoire, allocation des objets... ) Se concentrer sur les subtilités du langage Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 5 / 109
6 Introduction Historique Historique Développé par Sun Micro System Début du projet en 1991, première version publique en 1995 Objectif : télévision interactive C : 1972, C++ : 1979, Python : 1989 Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 6 / 109
7 Introduction Principes Principes Compilation/Exécution : Langage précompilé vers du byte code (class file) Exécution (interprétation) au travers de la JVM Write Once Run Anywhere ( Write Once Compile Anywhere) Langage : Tout est objet (... ou presque) Rien n existe en dehors d un objet Fortement (et statiquement) typé Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 7 / 109
8 Introduction Premier exemple Hello World HelloWorld.cpp C++ 1 #include<iostream > 2 using namespace std ; 3 int main ( int argc, const char * argv [ ] ) { 4 cout <<" Hello world!"<<endl ; 5 return 0; 6 } HelloWorld.java 1 public class HelloWorld { 2 public static void main ( String [ ] args ) { 3 System. out. println ( "Hello world!" ) ; 4 } 5 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 8 / 109
9 Introduction JVM Compilation traditionnelle en C++ a.out main.cpp #include<iostre using namespa int main(int arg cout<<"hello return Compiler Intel/Win. Compiler Intel/Mac. Exec Intel/Win a.out Exec Intel/Mac Vandy BERTEN INFO-F-202 Université Libre de Bruxelles 9 / 109
10 Introduction JVM Compilation en Hello.java public class He public static v System.out.pri } } Compiler Hello.class bytecode JVM Intel/Win JVM Intel/Mac Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 10 / 109
11 Introduction JVM Compilation $ javac HelloWorld.java # Compilation $ java HelloWorld # Exécution > Hello World! $ Console Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 11 / 109
12 Les bases Table des matières I 1 Introduction 2 Les bases Instructions simples Types primitifs Tableaux Classes et objets Passage de paramètres Types de langages Exceptions 3 et Orienté Objet 4 Threads Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 12 / 109
13 Les bases Table des matières II 5 Mais encore... Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 13 / 109
14 Les bases Instructions simples Instructions de base : la même chose? Instructions C++ Instructions 1 // Un commentaire 2 int n =5; 3 for ( int i =0; i<n ; ++i ) { 4 myfunction ( i ) ; 5 } 6 if ( V[0]%2 == 0) 7 dothis ( ) ; 8 else 9 dothat ( ) ; 10 /* Un autre commentaire 11 sur deux lignes */ 1 // Un commentaire 2 int n =5; 3 for ( int i =0; i<n ; ++i ) { 4 myfunction ( i ) ; 5 } 6 if ( V[0]%2 == 0) 7 dothis ( ) ; 8 else 9 dothat ( ) ; 10 /* Un autre commentaire 11 sur deux lignes */ Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 14 / 109
15 Les bases Instructions simples Instructions de base : pas tout à fait! Instructions C++ Instructions 1 int n=5, m =3; 2 double x =5.5; 3 float * V= new float [ n ] ; 4 if ( n ) 5 if ( n=5) { 6 int m =6; 7 m+n ; 8 m=x ; 9 x=n ; 10 } 1 int n=5, m =3; 2 double x = 5.5; 3 float V [ ] = new float [ n ] ; 4 if ( n ) // Illégal 5 if ( n=5) { // Illégal 6 int m =6; // Illégal 7 m+n ; // Illégal 8 m=x ; // Illégal 9 x=n ; 10 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 15 / 109
16 Les bases Instructions simples Boucle for-each for-each 1 int V [ ] = new int [ 1 0 ] ; 2 int sum =0; for ( int f : V ) { 5 sum += f ; 6 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 16 / 109
17 Les bases Types primitifs Types primitifs Nom #bits Remarque Wrapper boolean - true/false Boolean byte 8 C++ : signed char Byte char 16 C++ : 8 bits Char short 16 Short int 32 Integer long 64 Long idem C++ float 32 Float double 64 Double void - Void Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 17 / 109
18 Les bases Tableaux Tableaux En, tout tableau est un objet Tous les tableaux sont dynamiques (heap), jamais statiques (stack) créés via new Un tableau (= objet) possède un champ length de type final ( const en C++) C++ (dynamique) : pointeur vers le 1 er élément ; : référence vers le tableau entier Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 18 / 109
19 Les bases Tableaux Tableaux Tableaux dynamiques C++ Tableaux 1 int * a ; 2 a = new int [ 1 0 ] ; 3 delete [ ] a ; 4 a = new int [ 1 5 ] ; 5 int * b = a ; 6 int * * c = new int * [ 8 ] ; 7 for ( int i =0; i <8; ++i ) 8 c [ i ] = new int [ 8 ] ; 9 // Impossible! 1 int [ ] a ; // = int a[]; 2 a = new int [ 1 0 ] ; 3 4 a = new int [ 1 5 ] ; 5 int b [ ] = a ; 6 int c [ ] [ ] = new int [ 8 ] [ 8 ] ; a [ a. length 1]=4; Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 19 / 109
20 Les bases Tableaux Tableaux Tableaux statiques C++ Tableaux 1 int a [ 5 ] ; 2 3 // Impossible! 4 // Impossible! 5 int c [ 5 ] [ 5 ] ; 6 7 int d [ ] = { 1, 2, 3, 4 } ; 1 int [ ] a ; // = int a[]; 2 a = new int [ 5 ] ; 3 a = new int [ 9 ] ; 4 int b [ ] = a ; 5 int c [ ] [ ] = new int [ 5 ] [ 5 ] ; 6 7 int d [ ] = { 1, 2, 3, 4 } ; Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 20 / 109
21 Les bases Classes et objets Classes et objets : quelques différences Classes C++ Classes 1 class Foo { 2 private : 3 int x ; 4 public : 5 Foo ( ) : x ( 1 ) { } 6 int f ( int y=0) { 7 return y * x ; 8 } 9 } ; 1 class Foo { 2 3 private int x = 1; 4 5 public Foo ( ) { } 6 public int f ( int y ) { 7 return y * x ; 8 } 9 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 21 / 109
22 Les bases Classes et objets Classes et objets : quelques différences (suite) Objets 1 Foo a ; // Appelle Foo() 2 z = a. f ( 3 ) ; 3 4 Foo * b ; 5 b = new Foo ( ) ; 6 z = b >f ( 3 ) ; C++ Objets 1 Foo a ; 2 a = new Foo ( ) ; 3 z = a. f ( 3 ) ; Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 22 / 109
23 Les bases Classes et objets Classes et objets : quelques différences (suite) Après avoir rendu x public : Objets C++ Objets 1 Foo a ; 2 a. x = 3; 3 4 Foo b = a ; 5 b. x = 4; 1 Foo a = new Foo ( ) ; 2 a. x = 3; 3 4 Foo b = a ; 5 b. x = 4; Que valent a.x et b.x dans ces deux exemples? Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 23 / 109
24 Les bases Classes et objets Vecteurs et objets Vecteurs d objets 1 Foo * a = new Foo [ 1 0 ] ; C++ 10 appels à Foo() implicites Vecteurs d objets 1 Foo a [ ] = new Foo [ 1 0 ] ; 2 for ( int i =0; i<a. length ; ++i ) 3 a [ i ]= new Foo ( ) ; Et avec un for-each? Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 24 / 109
25 Les bases Classes et objets Variables En, une variable est : une variable primitive une référence ( pointeur) vers un objet ou un vecteur jamais un objet proprement dit pas de référence vers une primitive Variable primitive : sur le stack Objet/tableau : référence sur le stack, objet sur le heap Pas de * (objet pointé par), & (adresse de) ou -> (champ) Générer une matrice triangulaire de Integer de taille n : 1 élément pour M[0], n éléments pour M[n-1] Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 25 / 109
26 Les bases Passage de paramètres Passage de paramètres Le passage de paramètre se fait toujours par valeur... Mais pour un objet (ou tableau), c est la référence qui est passée par valeur Comment faire un swap? Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 26 / 109
27 Les bases Passage de paramètres Passage de paramètres 1 public void dosomething ( Point arg1, Point arg2 ) { 2 arg1. x = 100; 3 arg1. y = 100; 4 Point temp = arg1 ; 5 arg1 = arg2 ; 6 arg2 = temp ; 7 } 8 public static void main ( String [ ] args ) { 9 Point pnt1 = new Point ( 0, 0 ) ; 10 Point pnt2 = new Point ( 0, 0 ) ; 11 dosomething ( pnt1, pnt2 ) ; 12 } Que valent pnt1 et pnt2, avant et après dosomething? Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 27 / 109
28 Les bases Types de langages Types de langages Statiquement typé : & C++ Fortement/faiblement typé : plus fort que C++ Safe/unsafe : C++ autorise à peu près tous les cast, pas Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 28 / 109
29 Les bases Types de langages Sûreté de typage : C++ Safety1.cpp C++ 1 class Test1 { public : int a ; } ; 2 3 class Test2 { public : double b ; } ; 4 5 int main ( ) { 6 Test2 * t2 = new Test2 ( ) ; 7 t2 >b = 2. 4 ; 8 9 Test1 * t1 = ( Test1 * ) t2 ; // Not safe 10 cout << t1 >a << endl ; 11 return 0; 12 } Compile, avec un comportement aléatoire à l exécution Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 29 / 109
30 Les bases Types de langages Sûreté de typage : Safety1.java 1 class Test1 { public int a ; } 2 3 class Test2 { public double b ; } 4 5 public class Safety1 { 6 public static void main ( String [ ] arg ) { 7 Test2 t2 = new Test2 ( ) ; 8 t2. b = 2. 4 ; 9 10 Test1 t1 = ( Test1 ) t2 ; // Ne compile pas! 11 System. out. println ( t1. a ) ; 12 } 13 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 30 / 109
31 Les bases Exceptions Exceptions Idée : séparer le plus possible les cas normaux des cas problématiques Rend le code plus lisible, évite de nombreux tests (existence, bornes, nullité... ) Jamais de core dump en! En cas d erreur la JVM lance (throws) une exception Si on ne fait rien : arrêt du programme Deux réactions : tout arrêter, ou corriger l erreur et continuer On peut intercepter une exception : try... catch générer une exception : throw déclarer les exceptions d une méthode : throws Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 31 / 109
32 Les bases Exceptions Exception : interception 1 try { a [ i ] = x ; // 0 <= i < a.length? 4 s. dosomething ( ) ; // s!= null? 5 } catch ( IndexOutOfBoundsException e ) { 6 // Oops! 7 } catch ( NullPointException e ) { 8 e. printstacktrace ( ) ; 9 } finally { 10 // Clean up. Toujours exécuté 11 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 32 / 109
33 Les bases Exceptions Affichage du stack d appel printstacktrace() java.lang.nullpointerexception at MyTest.print(MyTest.java:19) at MyMainTest.doSomething(MyMainTest.java:13) at MyMainTest.main(MyMainTest.java:3) Console Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 33 / 109
34 Les bases Exceptions Exception : déclaration et génération 1 public int mytest ( int x ) throws Exception { 2 if ( x==0) { 3 throw new Exception ( "x==0!!" ) ; 4 } } try { 9 mytest ( x ) ; 10 } catch ( Exception e ) { 11 e. printstacktrace ( ) ; 12 throw e ; 13 } finally { 14 // Clean up. Toujours exécuté, même après le throw e 15 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 34 / 109
35 et Orienté Objet Table des matières I 1 Introduction 2 Les bases 3 et Orienté Objet Constructeurs et surcharge Modifiers Packages Héritage Interfaces Généricité 4 Threads Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 35 / 109
36 et Orienté Objet Table des matières II 5 Mais encore... Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 36 / 109
37 et Orienté Objet Constructeurs et surcharge Classes et Objets Tout doit être dans une classe! Les classes ont des champs (fields, data members) et des méthodes (methods, member functions) Une seule classe publique par fichier ( NomDeLaClasse.java ) Pas de séparation en-tête/corps Modifiers : private, public idem C++. protected et par défaut cf. packages et héritage Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 37 / 109
38 et Orienté Objet Constructeurs et surcharge Constructeur et surcharge Constructeur : méthode du même nom que la classe. Très similaire à C++ Différents constructeurs avec un nombre et/ou des types de paramètres différents : surcharge (overloading polymorphisme paramétrique) Pas de surcharge des opérateurs (+, []... ) Pas de paramètre par défaut Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 38 / 109
39 et Orienté Objet Constructeurs et surcharge Constructeurs et surcharge 1 class Point { 2 private int x, y ; 3 4 public Point ( int x, int y ) { this. x=x ; this. y=y ; } 5 public Point ( ) { this ( 0, 0) ; } 6 public Point ( double x, double y ) 7 { this ( ( int ) x, ( int ) y ) ; } 8 public Point ( Point p ) { this ( p. x, p. y ) ; } 9 } 10 class Test { 11 public static void main ( String [ ] argv ) { 12 Point p1 = new Point ( 1, 2) ; 13 Point p2 = new Point ( 1. 3, 2. 3 ) ; 14 Point p3 = new Point ( p2 ) ; 15 } 16 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 39 / 109
40 et Orienté Objet Constructeurs et surcharge Destructeur finalize Un équivalent du destructeur C++ : méthode finalize() Appellé lors que le Garbage Collector détruit l objet peut être très tard! Utile pour libérer des ressources utilisables jusqu à la fin (fichiers, sockets... ) Toujours appellée après un exit (même d erreur) finalize 1 Class A extends B { 2 protected void finalize ( ) { 3 super. finalize ( ) ; 4 // clean... 5 } 6 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 40 / 109
41 et Orienté Objet Modifiers Modifiers : final Un champ, une variable, une méthode peut être déclaré(e) final Champ ou variable final const Si primitive : valeur constante Si objet : la référence est constante, pas l objet! 1 final Foo a = new Foo ( 3 ) ; 2 a = new Foo ( 4 ) ; // Illégal 3 a. setvalue ( 4 ) ; // Légal Si l objet est immutable (String, Integer... ), il devient constant Sur des classes ou des méthodes cf. héritage Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 41 / 109
42 const et final et Orienté Objet Modifiers const C++ final 1 const Foo * a= new Foo ( ) ; 2 a >x = 5; // Illégal 3 a = new Foo ( ) ; // Légal 4 5 Foo * const b= new Foo ( ) ; 6 b >x = 5; // Légal 7 b = new Foo ( ) ; // Illégal 1 // Pas d équivalent final Foo b= new Foo ( ) ; 6 b. x = 5 ; // Légal 7 b= new Foo ( ) ; // Illégal Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 42 / 109
43 et Orienté Objet Modifiers Modifiers : static Définit une caractéristique de la classe (pas de l objet) static constant!! Méthode static : a uniquement accès à des champs/méthodes static peut être invoquée en dehors d un objet Champ static : copie commune à toutes les instances Une variable qui n est pas un champ ne peut pas être static! Pourquoi public static void main(string [] args)? Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 43 / 109
44 et Orienté Objet Packages Packages Les classes peuvent être regroupées en packages Structure hiérarchique : packagea.packageb.myclass Concept similaire au namespace et/ou include de C++ Package : nom complet 1 java. util. ArrayList list = new java. util. ArrayList ( ) ; Packages : importation 1 import java. util. ArrayList ; ArrayList list = new ArrayList ( ) ; Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 44 / 109
45 et Orienté Objet Packages Packages Le. sépare les entités : java.lang.system.out.println() : package java sous-package lang classe System champ (static) out fonction println() import java.util. * : importe toutes les classes de java.util import PackageA.PackageB.MyClass : cherche le fichier MyClass.class dans le répertoire PackageA/PackageB Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 45 / 109
46 et Orienté Objet Packages Fichier./PackageA/PackageB/MyClass.java 1 package PackageA. PackageB ; 2 public class MyClass { 3 public int x = 0; 4 public MyClass ( int x ) { this. x=x ; } 5 } Fichier./PackageC/HelloWorld.java 1 package PackageC ; 2 import PackageA. PackageB. MyClass ; 3 public class HelloWorld { 4 public static void main ( String args [ ] ) { 5 MyClass a = new MyClass ( 5 ) ; 6 System. out. println ( a. x ) ; 7 } } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 46 / 109
47 et Orienté Objet Packages Compilation Packages : compilation $ javac PackageA/PackageB/MyClass.java $ javac PackageC/HelloWorld.java Console $ java PackageC.HelloWorld Autre syntaxe $ cd PackageA/PackageB/ ; javac MyClass.java ; cd - $ cd PackageC/ ; javac HelloWorld.java ; cd - Console $ java PackageC/HelloWorld Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 47 / 109
48 et Orienté Objet Packages Classpath Si le package n est pas accessible depuis le répertoire courant : il faut préciser à javac et java le classpath Exemple : Mylib/PackageA/PackageB/MyClass.java Classpath $ javac -cp Mylib PackageC/HelloWorld.java $ java -cp Mylib:. PackageC.HelloWorld Console Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 48 / 109
49 et Orienté Objet Packages Jar On peut rassembler les.class dans une archive (fichier jar ) Jar $ jar cf mypackage.jar PackageA $ java -cp mypackage.jar:. PackageC.HelloWorld Console Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 49 / 109
50 et Orienté Objet Héritage Héritage Comme en C++, offre un mécanisme d héritage Héritage multiple interdit Par défaut, une classe hérite de Object Toute classe (sauf Object) hérite de une et une seule classe Un mécanisme d interface simule l héritage multiple Héritage = héritage public de C++ Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 50 / 109
51 et Orienté Objet Héritage Héritage En C++, on aura : Héritage C++ 1 class Derived : public Base {... } ; Deux significations : Derived peut faire tout ce que Base peut faire (et peut-être plus) héritage d interface Derived fait les choses de la même façon que Base, sauf si explicité héritage de méthode En : les deux concepts sont distincts Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 51 / 109
52 et Orienté Objet Héritage Héritage de méthode Héritage 1 class Base { 2 int f ( ) { /*... */ } 3 void g ( int x ) { /*... */ } 4 } 5 6 class Derived extends Base { 7 void g ( int x ) { /* overriding */ } 8 double h ( ) { /*... */ } 9 } Base : super-classe de Derived Derived : sous-classe de Base Redéfinition : overriding ( overloading), ou polymorphisme d héritage Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 52 / 109
53 et Orienté Objet Héritage Modifiers : private Base Dérivée C++ Classe : V V Objet : X X Classe : X X Objet : X X Classe : accessible au sein des fonctions de la classe Objet : accessible au contexte des instances Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 53 / 109
54 et Orienté Objet Héritage Modifiers : public Base Dérivée C++ Classe : V V Objet : V V Classe : V V public : V Objet : V protected : X private : X Classe : accessible au sein des fonctions de la classe Objet : accessible au contexte des instances Un seul niveau d héritage pour C++ Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 54 / 109
55 et Orienté Objet Héritage Modifiers : protected Base Dérivée C++ Classe : V V Objet : Même package : V Autre package : X X Classe : V V Objet : Même package : V Autre package : X X Classe : accessible au sein des fonctions de la classe Objet : accessible au contexte des instances Un seul niveau d héritage pour C++ Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 55 / 109
56 et Orienté Objet Héritage Modifiers : par défaut Base Dérivée Classe : Objet : Classe : Objet : V Même package : V Autre package : X Souvent comparé au friend de C++ Classe : accessible au sein des fonctions de la classe Objet : accessible au contexte des instances Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 56 / 109
57 et Orienté Objet Héritage Constructeurs et Héritage C++ et : crée implicitement un constructeur sans paramètre UNIQUEMENT si aucun constructeur avec paramètre n est défini! Héritage du constructeur : si pas de super(...) en première ligne, appelle le constructeur sans paramètre Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 57 / 109
58 et Orienté Objet Héritage Héritage et constructeur 1 class Parent { 2 Parent ( int x ) {... } 3 } 4 5 class Child extends Parent { 6 Child ( int y ) { 7 f ( y ) ; // Illégal 8 } 9 } Solutions : Écrire un constructeur sans paramètre pour Parent Commencer Child(int y) par super (...) Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 58 / 109
59 et Orienté Objet Héritage Abstract et Virtual Méthode non virtuelle C++ 1 class Base { 2 public : void echo ( ) { cout <<" Base"<<endl ; } 3 } ; 4 5 class Derived : public Base { 6 public : void echo ( ) { cout <<" Derived"<<endl ; } 7 } ; Base * a = new Base ( ) ; 10 Derived * b = new Derived ( ) ; a >echo ( ) ; 13 b >echo ( ) ; Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 59 / 109
60 et Orienté Objet Héritage Abstract et Virtual Méthode non virtuelle C++ 1 class Base { 2 public : void echo ( ) { cout <<" Base"<<endl ; } 3 } ; 4 5 class Derived : public Base { 6 public : void echo ( ) { cout <<" Derived"<<endl ; } 7 } ; Base 10 Base * a = new Base ( ) ; * b = new Derived ( ) ; a >echo ( ) ; 13 b >echo ( ) ; Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 60 / 109
61 et Orienté Objet Héritage Abstract et Virtual Héritage virtuel C++ 1 class Base { 2 public : virtual void echo ( ) { cout <<" Base"<<endl ; } 3 } ; 4 5 class Derived : public Base { 6 public : void echo ( ) { cout <<" Derived"<<endl ; } 7 } ; Base 10 Base * a = new Base ( ) ; * b = new Derived ( ) ; a >echo ( ) ; 13 b >echo ( ) ; Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 61 / 109
62 et Orienté Objet Héritage Abstract et Virtual Méthode virtuelle pure C++ 1 class Base { 2 public : virtual void echo ( ) =0; 3 } ; 4 5 class Derived : public Base { 6 public : void echo ( ) { cout <<" Derived"<<endl ; } 7 } ; Base * a = new Base ( ) ; // Illégal 10 Base * b = new Derived ( ) ; Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 62 / 109
63 et Orienté Objet Héritage Abstract et Virtual En : les méthodes sont toujours virtuelles pas de virtual Fonction virtuelle 1 class Base { 2 public void echo ( ) { System. out. println ( "Base" ) ; } 3 } 4 5 class Derived extends Base { 6 public void echo ( ) { System. out. println ( "Derived" ) ; } 7 } Base a = new Base ( ) ; 10 Base b = new Derived ( ) ; a. echo ( ) ; 13 b. echo ( ) ; Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 63 / 109
64 et Orienté Objet Héritage Abstract et Virtual Une méthode virtuelle pure est dite abstract ( force la redéfinition) Méthode abstract Classe abstract Méthode abstract 1 class abstract Base { 2 public void abstract echo ( ) ; 3 } 4 5 class Derived extends Base { 6 public void echo ( ) { System. out. println ( "Derived" ) ; } 7 } Base a = new Base ( ) ; // Illégal 10 Base b = new Derived ( ) ; Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 64 / 109
65 et Orienté Objet Héritage Abstract et Virtual abstract force la redéfinition final empêche la redéfinition Méthode final 1 class Base { 2 public void final echo ( ) { 3 System. out. println ( "Base" ) ; 4 } 5 } 6 7 class Derived extends Base { 8 public void echo ( ) {... } // Illégal 9 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 65 / 109
66 et Orienté Objet Héritage Abstract et Virtual Classe final 1 final class Base { 2 public void echo ( ) { 3 System. out. println ( "Base" ) ; 4 } 5 } 6 7 class Derived extends Base {... } // Illégal Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 66 / 109
67 et Orienté Objet Héritage Abstract et Virtual C++ Méthodes non virtuelles par défaut X Méthodes virtuelles virtual par défaut Méthodes virtuelles pures virtual=0 abstract Héritage final X final Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 67 / 109
68 et Orienté Objet Héritage final : synthèse final int a : variable non modifiable final MyClass a : référence non modifiable final int a(){} : méthode non redéfinissable final class a{} : classe non dérivable Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 68 / 109
69 et Orienté Objet Héritage Retour sur la sûreté de typage (type safety) Exemple de safety précédent : ne compilait pas Avec l héritage, on peut le mettre en défaut : compile, mais exception à l exécution Reste plus safe que C++! Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 69 / 109
70 et Orienté Objet Héritage Safety 1 class Parent { } 2 class Child1 extends Parent { public int a ; } 3 class Child2 extends Parent { public double b ; } 4 5 public class Safety2 { 6 public static void main ( String [ ] arg ) { 7 Child1 c1 = new Child1 ( ) ; c1. a = 5; 8 Child2 c2 = new Child2 ( ) ; c2. b = 2. 4 ; 9 Parent p = c1 ; // Down -conv. (safe) 10 Child1 pc1 = ( Child1 ) p ; // Up-conv. (unsafe) 11 System. out. println ( pc1. a ) ; // Ok 12 p = c2 ; // Safe 13 pc1 = ( Child1 ) p ; // Unsafe -> Exception 14 System. out. println ( pc1. a ) ; 15 } 16 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 70 / 109
71 et Orienté Objet Interfaces Interfaces Interface : classe purement abstraite (que des déclarations, sans aucune définition) class interface Constitue un contrat de ce que la classe s engage à implémenter On peut implémenter plusieurs interfaces Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 71 / 109
72 et Orienté Objet Interfaces Interfaces 1 interface MyIntf { 2 int f1 ( ) ; 3 } 4 5 interface MySubIntf extends MyIntf { 6 int f2 ( ) ; 7 } 8 9 public class MyClass extends AnotherClass 10 implements MySubIntf { 11 public int f1 ( ) {... } 12 public int f2 ( ) {... } 13 } MyIntf a = new MyClass ( ) ; Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 72 / 109
73 et Orienté Objet Généricité Généricité (Generics) Considérons un simple container Box qui contient un objet, et deux méthodes : add et get : Box 1 public class Box { 2 private Object object ; 3 4 public void add ( Object object ) { 5 this. object = object ; 6 } 7 public Object get ( ) { 8 return object ; 9 } 10 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 73 / 109
74 et Orienté Objet Généricité Classe Box : utilisation 1 Box integerbox = new Box ( ) ; 2 3 integerbox. add ( new Integer (10) ) ; 4 Integer someinteger1 = ( Integer ) integerbox. get ( ) ; 5 6 integerbox. add ( "10" ) ; 7 Integer someinteger2 = ( Integer ) integerbox. get ( ) ; Que se passe-t-il à la compilation? Que se passe-t-il à l exécution? Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 74 / 109
75 et Orienté Objet Généricité Solution : classe générique Classe Box générique 1 public class Box<T> { 2 private T t ; 3 4 public void add ( T t ) { 5 this. t = t ; 6 } 7 8 public T get ( ) { 9 return t ; 10 } 11 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 75 / 109
76 et Orienté Objet Généricité Generics vs. Template Generics Template C public class Box<T> { 3 private T t ; public void add ( T t ) { 7 this. t = t ; 8 } 9 10 public T get ( ) { 11 return t ; 12 } 13 } 1 template <class T> 2 class Box { 3 private : T t ; 4 5 public : 6 void add ( T t ) { 7 this >t = t ; 8 } 9 10 T get ( ) { 11 return t ; 12 } 13 } ; Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 76 / 109
77 et Orienté Objet Généricité Méthodes : Generics vs. Template Generics 1 public <U, V> U dosomething ( U u, V v ) { } Template C++ 1 template <class U, class V> 2 U dosomething ( U u, V v ) { } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 77 / 109
78 et Orienté Objet Généricité Généricité limitée Bounded type generics 1 public <U extends Number > void dosomething ( U u ) { 2 System. out. println ( u. doublevalue ( ) ) ; 3 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 78 / 109
79 et Orienté Objet Généricité Généricité et sous-typage Integer est un sous-type de Number. Donc un Integer est un Number. On peut donc écrire : 1 Integer i = new Integer ( 5 ) ; 2 Number n = i ; Donc dans une Box<Number>, on peut mettre des Integer : 1 Box<Number > bn = new Box<Number > ( ) ; 2 Integer i = new Integer ( 5 ) ; 3 Number n =... ; 4 bi. add ( i ) ; 5 bi. add ( n ) ; Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 79 / 109
80 et Orienté Objet Généricité Généricité et sous-typage Box<Integer> est-il un sous-type de Box<Number>? ou Un Box<Integer> est-il un Box<Number>? Autrement dit, peut-on écrire : 1 Box<Integer > bi = new Box<Integer > ( ) ; 2 Box<Number > bn = bi ; Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 80 / 109
81 et Orienté Objet Généricité Generics vs. Template (Generics) C++ (Templates) Quoi Uniquement références Tout type (objet ou prim.) + int Comment Une seule copie Copies séparées à la compilée compilation Spécialisation X V Valeur par défaut X V (classes) Type bounding V X Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 81 / 109
82 Threads Table des matières I 1 Introduction 2 Les bases 3 et Orienté Objet 4 Threads Définition et motivations Principes de base Synchronisation 5 Mais encore... Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 82 / 109
83 Threads Définition et motivations Définition Thread : processus léger (lightweight process) Processus : possède son propre contexte d exécution (stack) Léger : s exécute dans le contexte d un programme, et partage des ressources (heap) Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 83 / 109
84 Threads Définition et motivations Motivations Utilités : Puissance de modélisation Puissance d exécution Légèreté grâce au partage des données Meilleures performances au lancement et en exécution Facilités : Gestion des threads est intégrée au langage Simplicité d utilisation Thread = objet Primitives pour écrire des programmes concurrents et synchronisés Difficultés : Gérer la concurrence (synchronisation, sections critiques, deadlock) Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 84 / 109
85 Threads Définition et motivations Utilisations Animation dans un interface graphique (à intervalle régulier) Traitement en tâche de fond Application Client-Serveur Parallélisation d un algorithme Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 85 / 109
86 Threads Principes de base Classe java.lang.thread Thread 1 interface Runnable { 2 void run ( ) ; 3 } 4 5 class Thread implements Runnable { 6 Thread ( ) ; 7 Thread ( Runnable target ) ; 8 void run ( ) ; 9 void start ( ) ; } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 86 / 109
87 Threads Principes de base Exemple (extends Thread) BGSorter.java 1 class BGSorter extends Thread { 2 List l ; 3 public BGSorter ( List l ) { this. l = l ; } 4 public void run ( ) { /* sort l */ } 5 } List l = new ArrayList ( ) ; BGSorter sorter = new BGSorter ( l ) ; 10 sorter. start ( ) ; En quoi cette solution est-elle contraignante? Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 87 / 109
88 Threads Principes de base Exemple (implements Runnable) Exemple de thread 1 class BGSorter extends SomeClass implements Runnable { 2 List l ; 3 public BGSorter ( List l ) { this. l = l ; } 4 public void run ( ) { /* sort l */ } } List l = new ArrayList ( ) ; BGSorter sorter = new BGSorter ( l ) ; 11 Thread thread = new Thread ( sorter ) ; 12 thread. start ( ) ; Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 88 / 109
89 Threads Principes de base Exemple avec start automatique Exemple de thread 1 class BGSorter extends Thread { 2 List l ; 3 public BGSorter ( List l ) { this. l = l ; start() ; } 4 public void run ( ) { /* sort l */ } 5 } List l = new ArrayList ( ) ; BGSorter sorter = new BGSorter ( l ) ; Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 89 / 109
90 Threads Principes de base Méthodes diverses getname()/setname(string s) getpriority()/setpriority(int p) : p grand = haute priorité yield() : suggère au scheduler de prendre la main sleep(int millis) : pause setdaemon(boolean on) : programme s arrête lorsqu il ne reste plus que des démons!!! Runtime.exit(int status) sort du programme (tue tous les threads). Fin d un thread = sortie de run() Possibilité de hiérarchiser les threads en ThreadGroup Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 90 / 109
91 Threads Synchronisation Attendre la fin Thread et join 1 class BGSorter extends Thread { 2 List l ; 3 public BGSorter ( List l ) { this. l = l ; start ( ) ; } 4 public void run ( ) { /* sort l */ } 5 } List l = new ArrayList ( ) ; BGSorter sorter = new BGSorter ( l ) ; try { 12 sorter.join() ; 13 } catch ( InterruptedException e ) { /*... */ } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 91 / 109
92 Threads Synchronisation Sections critiques Difficulté de la programmation parallèle : les accès concurrents Exemple : s1 = new BGSorter(l) ; l.get(i).setvalue(4); Solution : verrouillage des objets synchronized synchronized 1 class MyListMgr { 2 List l ;... 3 public synchronized void sort ( ) { /* sort */ } 4 } public void run ( ) { // dans un Thread 7 // Do non critical stuffs 8 mylistmgr. sort ( ) ; 9 // Do non critical other stuffs 10 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 92 / 109
93 Threads Synchronisation Sections critiques On empêche deux tris en parallèle Mais accès en lecture/écriture sur List l toujours possible! Il faut rendre l accès synchronized Dans l exemple, le manager est verrouillé. Il faudrait verrouiller la liste List l Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 93 / 109
94 Threads Synchronisation Sections critiques synchronized private void sort ( ) { 3 synchronized ( l ) { 4 /* sort */ 5 } 6 } List mylist = new ArrayList ( ) ; 9 BGSorter sorter = new BGSorter ( mylist ) ; 10 synchronized ( mylist ) { 11 a = mylist. get ( 5 ) ; 12 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 94 / 109
95 Threads Synchronisation Exemple plus complet BGSorter (incomplet!!) 1 class BGSorter extends Thread { 2 List < Integer > list ; 3 4 public BGSorter ( List <Integer> l ) { list = l ; } 5 public void run ( ) { 6 for ( int i =0; i<list. size ( ) ; ++i ) 7 for ( int j =0; j<list. size ( ) i 1; ++j ) 8 if ( list. get ( j ) > list. get ( j+1) ) { 9 Integer tmp = list. get ( j ) ; 10 list. set ( j, list. get ( j+1) ) ; 11 list. set ( j+1, tmp ) ; 12 } 13 } 14 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 95 / 109
96 Threads Synchronisation Exemple plus complet Hypothèse : tous les éléments sont différents FindDuplicates (incomplet!!) 1 class FindDuplicates extends Thread { 2 boolean stop = false ; 3 List <Integer > list ; 4 5 public FindDuplicates ( List <Integer > l ) { list=l ; } 6 public void run ( ) { 7 while (! stop ) 8 for ( int i = 0; i < list. size ( ) 1; ++i ) 9 if ( list. get ( i ) == list. get ( i+1) ) 10 ; // print something 11 } 12 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 96 / 109
97 Threads Synchronisation Exemple plus complet Solutions pour éviter les accès concurrents synchronized(list) dans les deux run synchronized(list) plus local synchronized(list.get(i)) Vandy BERTEN INFO-F-202 Université Libre de Bruxelles 97 / 109
98 Threads Synchronisation Coordination de Threads Outre la concurrence, il faut souvent gérer la coordination Attendre des résultats d un autre threads, attendre un signal pour manipuler un objet... obj.wait() : le thread s endort sur obj obj.notify() : réveille un des threads endormis sur obj obj.notifyall() : réveille tous le threads endormis sur obj Ces trois méthodes : dans un bloc ou une méthode synchronized Une mise en attente libère le verrou (le reprend au réveil) Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 98 / 109
99 Threads Synchronisation Exemple de coordination On considère une file partagée, avec deux méthodes : push et pop Deux threads : un producteur, un consommateur Coordination 1 public class MyQueue { 2 private Queue q = new Queue ( ) ; 3 public synchronized void put ( Object o ) { 4 q. enqueue ( o ) ; 5 } 6 public synchronized Object get ( ) { 7 // Si la liste est vide, attendre un " push" 8 9 return q. dequeue ( ) ; 10 } 11 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 99 / 109
100 Threads Synchronisation Coordination : 1 ère mauvaise solution (sans wait/notify) 1 public class MyQueue { 2 private Queue q = new Queue ( ) ; 3 public synchronized void put ( Object o ) { 4 q. enqueue ( o ) ; 5 } 6 public synchronized Object get ( ) { 7 while ( q. isempty ( ) ) 8 ; 9 10 return q. dequeue ( ) ; 11 } 12 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 100 / 109
101 Threads Synchronisation Coordination : 2 ème mauvaise solution (avec wait/notify) 1 public class MyQueue { 2 private Queue q = new Queue ( ) ; 3 public synchronized void put ( Object o ) { 4 q. enqueue ( o ) ; 5 this.notify() ; 6 } 7 public synchronized Object get ( ) { 8 if ( q. isempty ( ) ) { 9 try { 10 this.wait() ; 11 } catch ( InterruptedException e ) { } 12 } 13 return q. dequeue ( ) ; 14 } 15 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 101 / 109
102 Threads Synchronisation Coordination : Bonne solution 1 public class MyQueue { 2 private Queue q = new Queue ( ) ; 3 public synchronized void put ( Object o ) { 4 q. enqueue ( o ) ; 5 this. notify ( ) ; 6 } 7 public synchronized Object get ( ) { 8 while ( q. isempty ( ) ) { 9 try { 10 this. wait ( ) ; 11 } catch ( InterruptedException e ) { } 12 } 13 return q. dequeue ( ) ; 14 } 15 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 102 / 109
103 Mais encore... Table des matières I 1 Introduction 2 Les bases 3 et Orienté Objet 4 Threads 5 Mais encore... Dynamic Class Loader et Réflexion doc Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 103 / 109
104 Mais encore... Dynamic Class Loader et Réflexion Dynamic Class Loader Implicitement : classes chargées dans la mémoire au plus tard Encore plus dynamique : nom d une classe connue à l exécution Exemple : plug-ins Utilisation des classes Object et Class Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 104 / 109
105 Mais encore... Dynamic Class Loader et Réflexion MyIntf.java 1 public interface MyIntf { String sayhello ( String a ) ; } MyTest.java (externe) 1 public class MyTest implements MyIntf { 2 public String sayhello ( String a ) { return " Hi "+a ; } } Dynamic Class Loader 1 try { 2 Class myclass = Class.forName ( " MyTest" ) ; 3 MyIntf test = ( MyIntf ) myclass.newinstance() ; 4 System. out. println ( test. sayhello ( "Bob" ) ) ; 5 } catch ( Exception e ) {... } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 105 / 109
106 Mais encore... Dynamic Class Loader et Réflexion MyTest.java (externe) 1 public class MyTest implements MyIntf { 2 String myname ; 3 public MyTest ( String name ) { myname = name ; } 4 public String sayhello ( String a ) { return "..." ; } 5 } Dynamic Class Loader 1 Class myclass = Class. forname ( "MyTest" ) ; 2 Class types [ ] = new Class [ ] { String. class } ; 3 Object args [ ] = new Object [ ] { "Bond" } ; 4 5 Constructor constr = myclass.getconstructor(types) ; 6 7 MyIntf test = ( MyIntf ) constr. newinstance ( args ) ; 8 System. out. println ( test. sayhello ( "James" ) ) ; Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 106 / 109
107 Mais encore... doc doc Système de documentation intégré HTML Reconnu par la plupart des IDE Permet la description structurée des classes, champs et méthodes Englobé dans /**... */ Tags de classe ou @since... Tags de @exception... Compilation : javadoc File.java Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 107 / 109
108 Mais encore... doc doc 1 /** Petite description de ma classe 2 Vandy BERTEN <vandy. berten@ulb. ac.be > */ 5 public class MyTest implements MyIntf { 6 /** Courte description ( avec point final). 7 * 8 * Un peu plus de blah blah. Peut être plus long <br > 9 * Peut même contenir des <u>balises </u> HTML. 10 * 11 name Blah Blah 12 MyException si quelque chose a foiré 13 Dit bonjour à name 14 */ 15 public String print ( String name ) 16 throws MyException {... } 17 } Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 108 / 109
109 Mais encore... doc Sources for C++ Programmers : and C++, a critical comparison (Robert C. Martin) Vandy BERTEN (vandy.berten@ulb.ac.be) INFO-F-202 Université Libre de Bruxelles 109 / 109
Introduction à Java. Matthieu Herrb CNRS-LAAS. Mars 2014. http://homepages.laas.fr/matthieu/cours/java/java.pdf
Introduction à Java Matthieu Herrb CNRS-LAAS http://homepages.laas.fr/matthieu/cours/java/java.pdf Mars 2014 Plan 1 Concepts 2 Éléments du langage 3 Classes et objets 4 Packages 2/28 Histoire et motivations
Plus en détailProgrammer en JAVA. par Tama (tama@via.ecp.fr( tama@via.ecp.fr)
Programmer en JAVA par Tama (tama@via.ecp.fr( tama@via.ecp.fr) Plan 1. Présentation de Java 2. Les bases du langage 3. Concepts avancés 4. Documentation 5. Index des mots-clés 6. Les erreurs fréquentes
Plus en détailUne introduction à Java
Une introduction à Java IFT 287 (Semaine 1) UNIVERSITÉ DE SHERBROOKE 1 Java - Historique Développé par Sun Microsystems en 1994 Inventeur James Gosling (canadien!) Objectif langage sûr (fortement typé)
Plus en détailThreads. Threads. USTL http://www.lifl.fr/ routier 1
Threads USTL http://www.lifl.fr/ routier 1 Rappels - Définitions un Process est un programme qui tourne et dispose de ses propres ressources mémoire. OS multi-tâche plusieurs process en concurrence un
Plus en détailPROGRAMMATION PAR OBJETS
PROGRAMMATION PAR OBJETS Java Environnement et constructions spécifiques Walter Rudametkin Maître de Conférences Bureau F011 Walter.Rudametkin@polytech-lille.fr B. Carré Polytech Lille 2 Java (Sun 1995)
Plus en détailINITIATION AU LANGAGE JAVA
INITIATION AU LANGAGE JAVA I. Présentation 1.1 Historique : Au début des années 90, Sun travaillait sur un projet visant à concevoir des logiciels simples et performants exécutés dans des PDA (Personnal
Plus en détailas Architecture des Systèmes d Information
Plan Plan Programmation - Introduction - Nicolas Malandain March 14, 2005 Introduction à Java 1 Introduction Présentation Caractéristiques Le langage Java 2 Types et Variables Types simples Types complexes
Plus en détailCours intensif Java. 1er cours: de C à Java. Enrica DUCHI LIAFA, Paris 7. Septembre 2009. Enrica.Duchi@liafa.jussieu.fr
. Cours intensif Java 1er cours: de C à Java Septembre 2009 Enrica DUCHI LIAFA, Paris 7 Enrica.Duchi@liafa.jussieu.fr LANGAGES DE PROGRAMMATION Pour exécuter un algorithme sur un ordinateur il faut le
Plus en détailJ2SE Threads, 1ère partie Principe Cycle de vie Création Synchronisation
J2SE Threads, 1ère partie Principe Cycle de vie Création Synchronisation Cycle Ingénierie 2e année SIGL Dernière mise à jour : 19/10/2006 Christophe Porteneuve Threads Principes Cycle de vie Création java.lang.thread
Plus en détailTP1 : Initiation à Java et Eclipse
TP1 : Initiation à Java et Eclipse 1 TP1 : Initiation à Java et Eclipse Systèmes d Exploitation Avancés I. Objectifs du TP Ce TP est une introduction au langage Java. Il vous permettra de comprendre les
Plus en détailStructure d un programme et Compilation Notions de classe et d objet Syntaxe
Cours1 Structure d un programme et Compilation Notions de classe et d objet Syntaxe POO 1 Programmation Orientée Objet Un ensemble d objet qui communiquent Pourquoi POO Conception abstraction sur les types
Plus en détailPlan du cours. Historique du langage http://www.oracle.com/technetwork/java/index.html. Nouveautés de Java 7
Université Lumière Lyon 2 Faculté de Sciences Economiques et Gestion KHARKIV National University of Economic Introduction au Langage Java Master Informatique 1 ère année Julien Velcin http://mediamining.univ-lyon2.fr/velcin
Plus en détailInitiation à JAVA et à la programmation objet. raphael.bolze@ens-lyon.fr
Initiation à JAVA et à la programmation objet raphael.bolze@ens-lyon.fr O b j e c t i f s Découvrir un langage de programmation objet. Découvrir l'environnement java Découvrir les concepts de la programmation
Plus en détailSynchro et Threads Java TM
Synchro et Threads Java TM NICOD JEAN-MARC Master 2 Informatique Université de Franche-Comté UFR des Sciences et Techniques septembre 2008 NICOD JEAN-MARC Synchro et Threads avec Java TM 1 / 32 Sommaire
Plus en détailJava 1.5 : principales nouveautés
Cours 6 - TEP - UPMC - 2008/2009 p. 1/34 Java 1.5 : principales nouveautés classes paramétrées : generics encapsulation des valeurs de types primitifs : auto[un]boxing itération sur les boucles types énumérés
Plus en détailJava Licence Professionnelle CISII, 2009-2010
Licence Professionnelle CISII, 2009-2010 Cours 1 : Introduction à Java A. Belaïd abelaid@loria.fr Cours disponible sur le site : http://www.loria.fr/~abelaid puis Teaching 1 Fonctionnement 12 séances :
Plus en détailTP1. Outils Java Eléments de correction
c sep. 2008, v2.1 Java TP1. Outils Java Eléments de correction Sébastien Jean Le but de ce TP, sur une séance, est de se familiariser avec les outils de développement et de documentation Java fournis par
Plus en détailLMI 2. Programmation Orientée Objet POO - Cours 9. Said Jabbour. jabbour@cril.univ-artois.fr www.cril.univ-artois.fr/~jabbour
LMI 2 Programmation Orientée Objet POO - Cours 9 Said Jabbour jabbour@cril.univ-artois.fr www.cril.univ-artois.fr/~jabbour CRIL UMR CNRS 8188 Faculté des Sciences - Univ. Artois Février 2011 Les collections
Plus en détailUn ordonnanceur stupide
Un ordonnanceur simple Université Paris Sud L objet des exercices qui suivent est de créer un ordonanceur implantant l algorithme du tourniquet ( round-robin scheduler ). La technique utilisée pour élire
Plus en détailJava c est quoi? Java pourquoi?
Grandes lignes du cours Cours JAVA : Le bases du langage Java. Version 3.02 Julien Sopena 1 1 julien.sopena@lip6.fr Équipe REGAL - INRIA Rocquencourt LIP6 - Université Pierre et Marie Curie Licence professionnelle
Plus en détailLa JVM. La machine virtuelle Java. La JVM. La JVM
La machine virtuelle Java Historique et rappels Organisation mémoire de la JVM Le garbage collector Le bytecode, la machine à pile. Les threads Suivi, tracé, optimisation d un programme Java JVM embarquées
Plus en détailAuto-évaluation Programmation en Java
Auto-évaluation Programmation en Java Document: f0883test.fm 22/01/2013 ABIS Training & Consulting P.O. Box 220 B-3000 Leuven Belgium TRAINING & CONSULTING INTRODUCTION AUTO-ÉVALUATION PROGRAMMATION EN
Plus en détailRemote Method Invocation Les classes implémentant Serializable
Parallélisme Architecture Eric Goubault Commissariat à l Energie Atomique Saclay Classe qui implémente la méthode distante (serveur): - dont les méthodes renvoient un objet serializable - ou plus généralement
Plus en détailINTRODUCTION A JAVA. Fichier en langage machine Exécutable
INTRODUCTION A JAVA JAVA est un langage orienté-objet pur. Il ressemble beaucoup à C++ au niveau de la syntaxe. En revanche, ces deux langages sont très différents dans leur structure (organisation du
Plus en détailDéveloppement Logiciel
Développement Logiciel Éxamen session 1-2012-2013 (Vendedi 25 mai, 9h-11h) Seuls les documents liés directement au cours sont autorisés (comme dit sur le site) : sujets de TD, notes de cours, notes personnelles
Plus en détailRN2-Programmation Orientée Objet - JAVA CH 1 Introduction à la POO et Java
RN2-Programmation Orientée Objet - JAVA CH 1 à la POO et Java Licence Professionnelle 2006 Agnès Guerraz INRIA Rhône-Alpes agnes.guerraz@inria.fr LP UPMF, Grenoble Septembre 2006 Ce cours reprend en grande
Plus en détailCours 1: Java et les objets
Ressources Les interface homme-machine et le langage Java DUT première année Henri Garreta, Faculté des Sciences (Luminy) Cyril Pain-Barre & Sébastien Nedjar, IUT d Aix-Marseille (Aix) Cours 1: infodoc.iut.univ-aix.fr/~ihm/
Plus en détailLangage Java. Classe de première SI
Langage Java Table des matières 1. Premiers pas...2 1.1. Introduction...2 1.2. Mon premier programme...2 1.3. Les commentaires...2 2. Les variables et les opérateurs...2 3. La classe Scanner...3 4. Les
Plus en détailGénéralités sur le Langage Java et éléments syntaxiques.
Généralités sur le Langage Java et éléments syntaxiques. Généralités sur le Langage Java et éléments syntaxiques....1 Introduction...1 Genéralité sur le langage Java....1 Syntaxe de base du Langage...
Plus en détailLangage et Concepts de ProgrammationOrientée-Objet 1 / 40
Déroulement du cours Introduction Concepts Java Remarques Langage et Concepts de Programmation Orientée-Objet Gauthier Picard École Nationale Supérieure des Mines de Saint-Étienne gauthier.picard@emse.fr
Plus en détailProjet de programmation (IK3) : TP n 1 Correction
Projet de programmation (IK3) : TP n 1 Correction Semaine du 20 septembre 2010 1 Entrées/sorties, types de bases et structures de contrôle Tests et types de bases Tests et types de bases (entiers) public
Plus en détailFacultés Universitaires Notre-Dame de la Paix. Conception et Programmation Orientées- Object
Facultés Universitaires Notre-Dame de la Paix Conception et Programmation Orientées- Object 2008-2009 RÉSUMÉ PRATIQUE... 4 CLASSE OBJET... 4 NOTION D HÉRITAGE... 4 LE POLYMORPHISME... 5 LES CLASSES ABSTRAITES...
Plus en détailEnvironnements de développement (intégrés)
Environnements de développement (intégrés) Tests unitaires, outils de couverture de code Patrick Labatut labatut@di.ens.fr http://www.di.ens.fr/~labatut/ Département d informatique École normale supérieure
Plus en détailF. Barthélemy. 17 mai 2005
Typage de la généricité en Java F. Barthélemy 17 mai 2005 1 Le shéma général La g én éricit é en Java est un ajout r éalis é sur un langage existant depuis d éjà une dizaine d ann ées, avec des contraintes
Plus en détailProgrammation en Java IUT GEII (MC-II1) 1
Programmation en Java IUT GEII (MC-II1) 1 Christophe BLANC - Paul CHECCHIN IUT Montluçon Université Blaise Pascal Novembre 2009 Christophe BLANC - Paul CHECCHIN Programmation en Java IUT GEII (MC-II1)
Plus en détailCalcul Parallèle. Cours 5 - JAVA RMI
Calcul Parallèle Cours 5 - JAVA RMI Eric Goubault Commissariat à l Energie Atomique & Chaire Ecole Polytechnique/Thalès Saclay Le 28 février 2012 Eric Goubault 1 28 février 2012 Remote Method Invocation
Plus en détailProgrammation Objet Java Correction
INSA - 4 AE 2007 2008 Durée : 1H00 Contrôle Programmation Objet Java Correction Consignes Tous les documents sont autorisés, mais ils seront peu utiles. Indiquez vos nom et prénom sur chaque feuille. Le
Plus en détailPour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère
L'héritage et le polymorphisme en Java Pour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère En java, toutes les classes sont dérivée de la
Plus en détailExceptions. 1 Entrées/sorties. Objectif. Manipuler les exceptions ;
CNAM NFP121 TP 10 19/11/2013 (Séance 5) Objectif Manipuler les exceptions ; 1 Entrées/sorties Exercice 1 : Lire un entier à partir du clavier Ajouter une méthode readint(string message) dans la classe
Plus en détailProgrammation Par Objets
Programmation Par Objets Structures de données package java.util B. Carré Polytech Lille 1 Tableaux et structures de données Tableaux «Objets» taille fixe type des éléments : primitif (homogène) ou objets
Plus en détailChapitre VI- La validation de la composition.
Chapitre VI- La validation de la composition. Objectifs du chapitre : Expliquer les conséquences de l utilisation de règles de typage souples dans SEP. Présenter le mécanisme de validation des connexions
Plus en détailAide mémoire UML & Java 1ère partie : Introduction. marc.lemaire@u-cergy.fr
Aide mémoire UML & Java 1ère partie : Introduction marc.lemaire@u-cergy.fr 9 septembre 2014 1 2014 v1.11 Table des matières 1 Généralités 6 1.1 Notations utilisées.....................................
Plus en détailIntroduction : les processus. Introduction : les threads. Plan
IN328 Programmation distribuée avec Java et J2EE 2 - Threads en Java Introduction : les processus Un processus est un ensemble d instructions à exécuter, un espace mémoire réservé et éventuellement d autres
Plus en détailIntroduction au langage C
Introduction au langage C Cours 1: Opérations de base et premier programme Alexis Lechervy Alexis Lechervy (UNICAEN) Introduction au langage C 1 / 23 Les premiers pas Sommaire 1 Les premiers pas 2 Les
Plus en détailExclusion Mutuelle. Arnaud Labourel Courriel : arnaud.labourel@lif.univ-mrs.fr. Université de Provence. 9 février 2011
Arnaud Labourel Courriel : arnaud.labourel@lif.univ-mrs.fr Université de Provence 9 février 2011 Arnaud Labourel (Université de Provence) Exclusion Mutuelle 9 février 2011 1 / 53 Contexte Epistémologique
Plus en détailJAVA. Introduction à la programmation objet avec java 1/4. Nadir BOUSSOUKAIA
JAVA Introduction à la programmation objet avec java 1/4 Nadir BOUSSOUKAIA v1.04 SOMMAIRE Caractéristiques de java (40mn) Eléments du langage (40mn) Les core API java (20mn) 2 Partie 1 Caractéristiques
Plus en détailApprendre la Programmation Orientée Objet avec le langage Java (avec exercices pratiques et corrigés)
Introduction à la POO 1. Histoire de la POO 9 2. Historique du 12 La conception orientée objet 1. Approche procédurale et décomposition fonctionnelle 13 2. La transition vers l'approche objet 14 3. Les
Plus en détailNotion de thread (1/2)
Notion de thread (1/2) La machine virtuelle java (JVM) permet d'exécuter plusieurs traitements en parallèle (en pratique, ils s'exécutent par tranche et en alternance sur le processeur). Ces traitements
Plus en détailNFP 121. Java et les Threads. Présentation : Thierry Escalarasse Mai 2007
NFP 121 Java et les Threads Présentation : Thierry Escalarasse Mai 2007 Plan du cour Présentation de la notion de Threads La classe Thread L interface Runnable Les états d un thread La Synchronisation
Plus en détailTP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile
TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile Dans ce TP, vous apprendrez à définir le type abstrait Pile, à le programmer en Java à l aide d une interface
Plus en détailHéritage presque multiple en Java (1/2)
Héritage presque multiple en Java (1/2) Utiliser deux classes ou plus dans la définition d'une nouvelle classe peut se faire par composition. class Etudiant{ int numero; Diplome d; float passeexamen(examen
Plus en détailLa technologie Java Card TM
Présentation interne au CESTI La technologie Java Card TM sauveron@labri.u-bordeaux.fr http://dept-info.labri.u-bordeaux.fr/~sauveron 8 novembre 2002 Plan Qu est ce que Java Card? Historique Les avantages
Plus en détailPackage Java.util Classe générique
Package Java.util Classe générique 1 Classe Vector La taille est dynamique: dès qu un tableau vectoriel est plein, sa taille est doublée, triplée, etc. automatiquement Les cases sont de type Object add(object
Plus en détailInfo0604 Programmation multi-threadée. Cours 5. Programmation multi-threadée en Java
Info0604 Programmation multi-threadée Cours 5 Programmation multi-threadée en Java Pierre Delisle Université de Reims Champagne-Ardenne Département de Mathématiques et Informatique 18 février 2015 Plan
Plus en détailIntroduction au langage Java
Introduction au langage Java 1 Introduction : Langage développé par Sun et purement orienté objet. N a pas de rapport direct avec Javascript développé par Netscape. Les applications java peuvent être des
Plus en détailEncapsulation. L'encapsulation consiste à rendre les membres d'un objet plus ou moins visibles pour les autres objets.
Encapsulation L'encapsulation consiste à rendre les membres d'un objet plus ou moins visibles pour les autres objets. La visibilité dépend des membres : certains membres peuvent être visibles et d'autres
Plus en détailPolycopié Cours Programmation Orientée Objet sous Java Programme : Filière SMI S5
UNIVERISTE MOHAMMED PREMIER Faculté des Sciences d Oujda Oujda - Maroc Polycopié Cours Programmation Orientée Objet sous Java Programme : Filière SMI S5 Pr. El Mostafa DAOUDI Département de Mathématiques
Plus en détailInfo0101 Intro. à l'algorithmique et à la programmation. Cours 3. Le langage Java
Info0101 Intro. à l'algorithmique et à la programmation Cours 3 Le langage Java Pierre Delisle, Cyril Rabat et Christophe Jaillet Université de Reims Champagne-Ardenne Département de Mathématiques et Informatique
Plus en détailChapitre 10. Les interfaces Comparable et Comparator 1
Chapitre 10: Les interfaces Comparable et Comparator 1/5 Chapitre 10 Les interfaces Comparable et Comparator 1 1 Ce chapitre a été extrait du document "Objets, Algorithmes, Patterns" de [René Lalement],
Plus en détail1 Définition d une classe en Java
Université Montpellier-II UFR des Sciences - Département Informatique Licence Informatique - Ingénierie Logicielle - Concepts et Outils de la modélisation et du développement de logiciel par et pour la
Plus en détailRemote Method Invocation en Java (RMI)
Remote Method Invocation en Java (RMI) Modélisation et construction des applications réparties (Module M-4102C) J. Christian Attiogbé Fevrier 2015 J. Christian Attiogbé (Fevrier 2015) Remote Method Invocation
Plus en détailLicence Bio Informatique Année 2004-2005. Premiers pas. Exercice 1 Hello World parce qu il faut bien commencer par quelque chose...
Université Paris 7 Programmation Objet Licence Bio Informatique Année 2004-2005 TD n 1 - Correction Premiers pas Exercice 1 Hello World parce qu il faut bien commencer par quelque chose... 1. Enregistrez
Plus en détailCours 1 : Introduction. Langages objets. but du module. contrôle des connaissances. Pourquoi Java? présentation du module. Présentation de Java
Langages objets Introduction M2 Pro CCI, Informatique Emmanuel Waller, LRI, Orsay présentation du module logistique 12 blocs de 4h + 1 bloc 2h = 50h 1h15 cours, 45mn exercices table, 2h TD machine page
Plus en détailJADE : Java Agent DEvelopment framework. Laboratoire IBISC & Départ. GEII Université & IUT d Evry nadia.abchiche@ibisc.univ-evry.
: Java Agent DEvelopment framework Laboratoire IBISC & Départ. GEII Université & IUT d Evry nadia.abchiche@ibisc.univ-evry.fr Introduction à la plateforme JADE 1) Modèle d agent 2) Services 3) Norme FIPA
Plus en détailRemote Method Invocation (RMI)
Remote Method Invocation (RMI) TP Réseau Université Paul Sabatier Master Informatique 1 ère Année Année 2006/2007 Plan Objectifs et Inconvénients de RMI Fonctionnement Définitions Architecture et principe
Plus en détailBases Java - Eclipse / Netbeans
Institut Galilée PDJ Année 2014-2015 Master 1 Environnements Java T.P. 1 Bases Java - Eclipse / Netbeans Il existe plusieurs environnements Java. Il est ESSENTIEL d utiliser la bonne version, et un environnement
Plus en détailJava c est quoi? Java. Java. Java : Principe de fonctionnement 31/01/2012. 1 - Vue générale 2 - Mon premier programme 3 - Types de Programme Java
1 - Vue générale 2 - Mon premier programme 3 - Types de Programme 1 2 c est quoi? Technologie développée par SUN Microsystems lancée en 1995 Dans un des premiers papiers* sur le langage JAVA, SUN le décrit
Plus en détailPremiers Pas en Programmation Objet : les Classes et les Objets
Chapitre 2 Premiers Pas en Programmation Objet : les Classes et les Objets Dans la première partie de ce cours, nous avons appris à manipuler des objets de type simple : entiers, doubles, caractères, booléens.
Plus en détailProblèmes liés à la concurrence
ENS Cachan Problématique Difficile de gérer la concurrence : Pas toujours facile d avoir des fonctions réentrantes. Risque de race condition : ex : x :=x+1 x :=x+1 On voudrait des blocs d instructions
Plus en détailJava - la plateforme
Java - la plateforme Java la plateforme Java? VM GC JIT Java Aujourd'hui 3 environnements d'exécutions différents Java ME (Micro Edition) pour PDA, téléphone Android (Java SE moins certain paquetages)
Plus en détailBases du langage. Historique Applications et applets Éléments de base du langage Classes et objets Les exceptions
Langage JAVA Bases du langage Opérations sur les fichiers Réseau Multi-tâche Logiciel: interfaces... Gestion des périphériques (méthodes natives) Accès aux bases de données Bases du langage Historique
Plus en détailPrésentation de Java. Olivier de Pertat IT GROUP
Présentation de Java Olivier de Pertat IT GROUP Qu'est-ce que Java? Un langage de programmation orienté objets Une architecture de Virtual Machine Un ensemble d'api variées Un ensemble d'outils : le Java
Plus en détailJava Licence Professionnelle CISII, 2009-10
Java Licence Professionnelle CISII, 2009-10 Cours 4 : Programmation structurée (c) http://www.loria.fr/~tabbone/cours.html 1 Principe - Les méthodes sont structurées en blocs par les structures de la programmation
Plus en détailP r ob lé m a t iq u e d e la g é n é r icit é. Pr in cip e d e la g é n é r icit é e n Ja v a ( 1 /3 )
P r ob lé m a t iq u e d e la g é n é r icit é les versions de Java antérieures à 1.5 permettaient de créer des classes de structures contenant n'importe quels types d'objet : les collections (classes
Plus en détail4. Outils pour la synchronisation F. Boyer, Laboratoire Lig Fabienne.Boyer@imag.fr
4. Outils pour la synchronisation F. Boyer, Laboratoire Lig Fabienne.Boyer@imag.fr Le problème Insuffisance des solutions de base (verrous) Les solutions de plus haut niveau Les Sémaphores Les Moniteurs
Plus en détailLOG4430 : Architecture et conception avancée
LOG4430 : Architecture et conception avancée Abdou Maiga Patrons pour la conception d applications distribuées Département de génie informatique et de génie logiciel École Polytechnique de Montréal Guéhéneuc,
Plus en détailLOG4430 : Architecture logicielle et conception avancée
LOG4430 : Architecture logicielle et conception avancée Yann-Gaël Guéhéneuc Cours 3 Bibliothèques et chargement Dynamique de composants Département de génie informatique et de génie logiciel École Polytechnique
Plus en détailRMI. Remote Method Invocation: permet d'invoquer des méthodes d'objets distants.
RMI Remote Method Invocation: permet d'invoquer des méthodes d'objets distants. Méthode proche de RPC. Outils et classes qui rendent l'implantation d'appels de méthodes d'objets distants aussi simples
Plus en détailObjets et Programmation. origine des langages orientés-objet
Objets et Programmation origine des langages orientés-objet modularité, encapsulation objets, classes, messages exemples en Java héritage, liaison dynamique G. Falquet, Th. Estier CUI Université de Genève
Plus en détailProgrammation Orientée Objet Java
Programmation Orientée Objet Java Bertrand Estellon Département Informatique et Interactions Aix-Marseille Université 12 novembre 2014 Bertrand Estellon (DII AMU) Programmation Orientée Objet Java 12 novembre
Plus en détailProgrammation Réseau. Sécurité Java. Jean-Baptiste.Yunes@univ-paris-diderot.fr. UFR Informatique 2012-2013. jeudi 4 avril 13
Programmation Réseau Sécurité Java Jean-Baptiste.Yunes@univ-paris-diderot.fr UFR Informatique 2012-2013 Java Sécurité? différentes sécurités disponibles et contrôlables intégrité contrôle d accès signature/authentification/cryptographie
Plus en détailApprendre Java en 154 minutes
Apprendre Java en 154 minutes Tutorial Java 1.6 - HESB-TI Stéphanie Calderara José R. Beuret Quentin Cosendey Mai 2008 Table des matières 1 Objet, classe et modificateur 3 1.1 Le premier pas..........................
Plus en détailCommunication inter-processus (IPC) : tubes & sockets. exemples en C et en Java. F. Butelle
F. Butelle, E. Viennet, Système GTR2 IUT Paris 3 Communication inter-processus (IPC) : tubes & sockets exemples en C et en Java F. Butelle F. Butelle, E. Viennet, Système GTR2 IUT Paris 3 Java : implémentation
Plus en détailUtilisation d objets : String et ArrayList
Chapitre 6 Utilisation d objets : String et ArrayList Dans ce chapitre, nous allons aborder l utilisation d objets de deux classes prédéfinies de Java d usage très courant. La première, nous l utilisons
Plus en détailJava RMI. Arnaud Labourel Courriel: arnaud.labourel@lif.univ-mrs.fr. Université de Provence. 8 mars 2011
Java RMI Arnaud Labourel Courriel: arnaud.labourel@lif.univ-mrs.fr Université de Provence 8 mars 2011 Arnaud Labourel (Université de Provence) Java RMI 8 mars 2011 1 / 58 Web services Services par le réseau
Plus en détailCOMPARAISONDESLANGAGESC, C++, JAVA ET
REPUBLIQUE DU BENIN *******@******* MINISTERE DE L ENSEIGNEMENT SUPERIEUR ET DE LA RECHERCHE SCIENTIFIQUE(MESRS) *******@******* UNIVERSITE D ABOMEY CALAVI(UAC) *******@******* ECOLE POLYTECHNIQUE D ABPOMEY
Plus en détailTraitement de données
Traitement de données Présentation du module TINI Présentation du module : Le module Tini se décline en plusieurs versions, il est constitué d une carte d application et d un module processeur : Les modules
Plus en détailWeb Tier : déploiement de servlets
Web Tier : déploiement de servlets 1 / 35 Plan 1 Introduction 2 Servlet : Principe de fonctionnement 3 Création et développement sur un serveur JEE 4 Quelques méthodes de l API des servlets 5 Utilisation
Plus en détailCorrigés des premiers exercices sur les classes
Corrigés des premiers exercices sur les classes Exercice 2.1.1 utilisation d une classe Voici le texte d une classe représentant de façon sommaire un compte bancaire et les opérations bancaires courantes.
Plus en détailINF 321 : mémento de la syntaxe de Java
INF 321 : mémento de la syntaxe de Java Table des matières 1 La structure générale d un programme 3 2 Les composants élémentaires de Java 3 2.1 Les identificateurs.................................. 3 2.2
Plus en détailJAVA TD0. Prise en main du langage Environnement de base JAVA 1
JAVA TD0 Prise en main du langage Environnement de base JAVA 1 Mon premier programme public class HelloWorld { public static void main(string [] arg){ System.out.println("Hello, World!"); main(string []
Plus en détailTp 1 correction. Structures de données (IF2)
Tp 1 correction Structures de données (IF2) Remarque générale : compilez et exécutez le code au-fur-et-à mesure de son écriture. Il est plus facile de corriger une petite portion de code délimitée que
Plus en détailPrénom : Matricule : Sigle et titre du cours Groupe Trimestre INF1101 Algorithmes et structures de données Tous H2004. Loc Jeudi 29/4/2004
Questionnaire d'examen final INF1101 Sigle du cours Nom : Signature : Prénom : Matricule : Sigle et titre du cours Groupe Trimestre INF1101 Algorithmes et structures de données Tous H2004 Professeur(s)
Plus en détailLicence ST Université Claude Bernard Lyon I LIF1 : Algorithmique et Programmation C Bases du langage C 1 Conclusion de la dernière fois Introduction de l algorithmique générale pour permettre de traiter
Plus en détailTD/TP PAC - Programmation n 3
Université Paris Sud Licence d informatique/iup-miage2 Année 2004-2005 Auteur : Frédéric Vernier Semaine : 11-16 octobre 2004 Conditions : sur machine avec les outils standards java web: http://vernier.frederic.free.fr/indexpac.html
Plus en détailTD3: tableaux avancées, première classe et chaînes
TD3: tableaux avancées, première classe et chaînes de caractères 1 Lestableaux 1.1 Élémentsthéoriques Déclaration des tableaux Pour la déclaration des tableaux, deux notations sont possibles. La première
Plus en détailUne introduction à la technologie EJB (2/3)
Une introduction à la technologie EJB (2/3) 1 Les singletons des EJB 3.1 1.1 Synchronisation gérée manuellement Depuis la version 3.1, des EJB Statless à instance unique sont maintenant disponibles : ce
Plus en détailDerrière toi Une machine virtuelle!
Derrière toi Une machine virtuelle! Yann-Gaël Guéhéneuc guehene@emn.fr École des Mines de Nantes, France Object Technology International Inc., Canada D où ça vient? Calculatrice Machine de Turing 1936
Plus en détailRMI le langage Java XII-1 JMF
Remote Method Invocation (RMI) XII-1 Introduction RMI est un ensemble de classes permettant de manipuler des objets sur des machines distantes (objets distants) de manière similaire aux objets sur la machine
Plus en détailJava Licence professionnelle CISII, 2009-2010
Java Licence professionnelle CISII, 2009-2010 Cours 6 : le paquetage (package) Cours inspiré des cours de Richard Grin, Antoine Tabbone et Hazel Everett 1 Définition - Les classes Java sont regroupées
Plus en détail