La JVM. La machine virtuelle Java. La JVM. La JVM
|
|
- Huguette Bonin
- il y a 2 ans
- Total affichages :
Transcription
1 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 ENST Dép. INFRES 107 ENST Dép. INFRES 108
2 Plan 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 ENST Dép. INFRES 109 ENST Dép. INFRES 110
3 Rappels Les compilateurs java produisent un fichier contenant une représentation appelée bytecode. Ce code n'est exécutable sur aucun processeur, il sera interprété par une machine virtuelle java ou JVM (Java Virtual Machine). C'est à dire que chaque instruction du bytecode sera lue et décodée puis traduite en langage machine local. Un exécutable Java fonctionnera donc aussi bien sur un PC que sur une station Sun ou sur un MacIntosh où qu'il ait été compilé, pourvu que l on dispose d une JVM sur la machine cible. Machine 1 Fichier source java javac Fichier objet (bytecode) Machine 2 JVM Matériel JIT class loader native methods Système d'exploitation java Objectif!:du bytecode!:!write once, run anywhere! ENST Dép. INFRES 111 ENST Dép. INFRES 112
4 VM de JVM!: Historique L ancêtre des machine virtuelle!: à l université UCSD dans les années 70!: le p-system basé sur le langage Pascal. Sun, année 1992!: P. Naughton, M. Sheridan et J. Gosling mettent au point Oak et la machine virtuelle associée. Cet environnement est destiné aux systèmes embarqués, échec!. Repris en 1995 et renommé en Java, Oak est proposé comme outil pour développer des applications Web. (Java, c est le C++ sans les couteaux ni les revolvers dixit Gosling). ENST Dép. INFRES 113 ENST Dép. INFRES 114
5 VM de JVM!: Spécificités Les principaux modules d une JVM!: - Le chargeur de classes (class loader) - L interprète de bytecode, JITcompiler - Le garbage collector - Et aussi!: les E/S, le graphique, la sécurité, ne fait pas d hypothèses sur le matériel qui l accueille!: - Pas d hypothèse sur le nombre de registres -> la JVM est une machine à pile - Les seuls registres utilisés seront!: un compteur ordinal, et trois registres pour gérer la pile Portabilité, attention aux liens avec le matériel et le système!: - Gestion des threads (priorités), gestion du garbage collector - Gestion du graphique, gestion des E/S ENST Dép. INFRES 115 ENST Dép. INFRES 116
6 Rappels!: J de JVM Différence entre classe et objet!: un objet est l instance d une classe. Les tableaux et les String sont des objets. Différence entre variables et méthodes de classe, variables et méthodes d instance!: Une méthode d instance est invoquée sur un objet et a accès aux variables associées à cette instance Pour créer un objet!: appel à new, ou à certaines méthodes comme getbyname, valueof Attention!: L accès aux objets se fait par référence (un pointeur + des éléments de vérification). En effet, les paramètres sont passés par valeur, et pour un objet, on passe la valeur de cette référence. ENST Dép. INFRES 117 ENST Dép. INFRES 118
7 Plan 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 Organisation ENST Dép. INFRES 119 ENST Dép. INFRES 120
8 Organisation Mémoire de la JVM L espace des méthodes (des exécutables!), c est ici que se trouve le bytecode proprement dit, le CO pointe sur l instruction à exécuter. Il contient aussi les tables de symboles. La zone des constantes, les tables associées aux méthodes, les définitions des classes sont rangées dans un tas non géré par le GC La pile où sont rangées les frames (cadres) d invocation des méthodes. Elle est gérée par les trois pointeurs frame, vars et optop. Il y a une pile par thread. Les registres sont le CO et trois pointeurs pour gérer la pile!: il y a un jeu de registres par thread. Le tas (heap) où sont rangés les objets (instances des classes et les tableaux). Il est parcouru régulièrement par le ramasse-miettes. Un seul tas. Si la taille de l une de ces zones ne permet pas l exécution d un thread, l exception OutOfMemoryError est envoyée par la JVM. Remarque!: les variables locales sont implantées sur la pile, les objets (créés par new) sont implantés sur le tas. ENST Dép. INFRES 121 ENST Dép. INFRES 122
9 Organisation Mémoire de la JVM Organisation logique de la JVM!: Espace des méthodes Les bytescodes des méthodes Registres (un jeu par thread) CO SP Pile Une par thread Tas Commun à tous les objets ENST Dép. INFRES 123 ENST Dép. INFRES 124
10 L espace des méthodes Contient le bytecode des méthodes, des constructeurs et des informations telles que la table des symboles Contient aussi les informations de typage sur les objets (nom, modifier, nom de la superclasse, nombre et noms des interfaces implémentées, nombre de méthodes, et pour chaque méthode, un descripteur (nom, nombre de paramètres, table des exceptions, ) cf instanceof qui vérifie la classe d un objet constant pool ENST Dép. INFRES 125 ENST Dép. INFRES 126
11 La pile et les registres associés Chaque thread dispose de sa propre pile La pile contient!: les paramètres passés aux méthodes exécutées, les valeurs retournées par ces méthodes, leur état, les variables locales. La pile est un ensemble de frames, elle est gérée par les pointeurs frame (qui donne le frame de la méthode courante), vars et optop Une frame se divise en trois parties!: -la pile où sont rangés les opérandes des instructions du bytecode (partie repérée par le pointeur optop) - l environnement d exécution, pour retrouver l état de la méthode exécutée (partie repérée par le pointeur frame) - variables locales de la méthode (partie repérée par le pointeur vars) Remarque!: - durée de vie d un objet dans le tas!: de new à sa suppression par le GC - durée de vie d une variable locale!sur la pile : de sa création au retour de la méthode qui l utilise, ENST Dép. INFRES 127 ENST Dép. INFRES 128
12 Le tas Le tas héberge tous les objets d un programme. Chaque appel à new entraîne une allocation de mémoire sur le tas. Le tas est partagé par tous les threads La gestion du tas est prise en charge par la JVM Attention!: La spécification de la JVM ne dit pas comment doit fonctionner le garbage collector. (L'algorithme le plus employé est de type mark and sweep). ENST Dép. INFRES 129 ENST Dép. INFRES 130
13 Plan 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 ENST Dép. INFRES 131 ENST Dép. INFRES 132
14 Le Garbage collector (ramasse miettes) Sur le tas sont rangés les objets créés lors de l exécution d un programme (appel à new)!. Le GC se charge en particulier de libérer l espace occupé par les objets qui ne sont plus référencés. Le GC recycle l espace mémoire!: - récupération des blocs libres, - exécution des «!finalizers!» - gestion de la fragmentation (pénalisante même dans le cas d une mémoire paginée!: on augmente le taux de pagination) par compactage et garbage collection, Fonctionnement du GC!: - plusieurs algorithmes sont utilisés!: mark and sweep est le plus courant - le GC automatique libère le programmeur des pbs de gestion du tas, il garantit que la JVM ne s arrête pas à cause d un pb mémoire - inconvénients!: overhead, non déterminisme (par exemple, les finalizers sont exécutés par le GC, on ne peut donc pas savoir précisément quand), plus de temps consommé que s il était fait à la demande - fait par un thread dédié, appels explicites!: System.gc() et Runtime.gc() (immédiat sur Sun et NT) ENST Dép. INFRES 133 ENST Dép. INFRES 134
15 Configuration et suivi du Garbage collector L option -verbose:gc de la commande java trace les appels au Garbage Collector Options de la commande java pour affiner le dimensionnement des zones utilisées par le GC!: - Xmx : modification de la taille du tas (défaut de 64Mo, souvent insuffisant) - Xms : la taille minimale du tas (faire Xms = Xmx) - -XX:NewRatio=n : n est le ratio entre l'ancienne et la jeune génération (celle-ci doit utiliser plus de 50 % du tas) - noasync!: pas de GC asynchrone (le thread de GC n est pas utilisé), seulement à la demande, ou si l on n a plus de mémoire - noclassgc!: pas de GC pour les classes inutilisées ENST Dép. INFRES 135 ENST Dép. INFRES 136
16 GC!: Exemple(1) class TesT_Threads { public static void main (String args[]) { for (int i=0; i < 20; i++){ new MonThread("_Thread_" + i).start(); } System.out.println("GC 1 : AVANT"); System.gc(); System.out.println("GC 1 : APRES"); for (int i=0; i < 200; i++) new MonThread(" Thread_" + i).start(); System.out.println("GC 2 : AVANT"); Runtime r = Runtime.getRuntime() ; // Quantite de memoire libre long free = r.freememory(); // Quantite de memoire diponible, allouee et non-allouee long total = r.totalmemory(); // Quantite de memoire allouee long inuse = r.totalmemory() - r.freememory() ; System.out.println(" free =" + free + " total="+ total+ " inuse="+ inuse); System.gc(); System.out.println("GC 2 : APRES"); while (true) {}; } } class MonThread extends Thread { public MonThread(String str) { super(str); } public void run() { for (int i = 0; i < 10; i++) { try { sleep((int)(math.random() * 1000)); } catch (InterruptedException e) {} } } } ENST Dép. INFRES 137 ENST Dép. INFRES 138
17 GC!: Exemple (2) Exécution du programme sur JVM 1.3 : java -verbosegc -noasyncgc TesT_Threads Warning: -noasyncgc option is no longer supported. GC 1 : AVANT [Full GC 1198K->316K(3520K), secs] GC 1 : APRES GC 2 : AVANT free = total= inuse= [Full GC 380K->347K(5248K), secs] GC 2 : APRES Exécution du programme sur JVM 1.1 : $ java -verbosegc -noasyncgc TesT_Threads GC 1 : AVANT <GC: heap 5120K, total before 1338K, after 1317K (6588/6260 objs) 74.3% free, alloced 7083K (#11941), marked 94K, swept 21K (#328) 0 objs (0K) awaiting finalization> GC 1 : APRES <GC: heap 5120K, total before 4548K, after 4461K (8346/7267 objs) 12.9% free, alloced 3235K (#2090), marked 299K, swept 86K (#1079) 0 objs (0K) awaiting finalization> <GC: heap 7168K, total before 6379K, after 6297K (8530/7914 objs) 12.1% free, alloced 1917K (#1263), marked 439K, swept 81K (#616) 0 objs (0K) awaiting finalization> GC 2 : AVANT free = total= inuse= <GC: heap 9216K, total before 7946K, after 7871K (8995/8425 objs) 14.6% free, alloced 1704K (#1151), marked 539K, swept 75K (#570) 0 objs (0K) awaiting finalization> GC 2 : APRES ENST Dép. INFRES 139 ENST Dép. INFRES 140
18 Plan 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 ENST Dép. INFRES 141 ENST Dép. INFRES 142
19 Qu est ce qu une Machine à pile Soit l instruction!écrite en langage de haut niveau : i = j + k!; Code généré sur une machine à pile!(mp) : push j /* mettre j en haut de pile */ push k /* mettre k en haut de pile */ add /* additionner les deux valeurs et les dépiler empiler le résultat *!/ store i /* prendre le sommet de pile et le ranger dans i */ Comptons les accès à la mémoire!: L pour load (mémoire vers pile), S pour store (pile vers mémoire)!: push j /* L S */ push k /* L S */ add /* L L S */ store i /* L S */ il y plus d accès mémoire que sur un processur doté de registres, mais moins de temps est passé en décodage et recherche des opérandes Dans le cas de la compilation à la volée (just in time compiler, JIT), il faut gérer l allocation des registres à partir du bytecode ENST Dép. INFRES 143 ENST Dép. INFRES 144
20 Exécution D un programme Java!: généralités Un programme Java est organisé en fichiers objets appelés classes, chaque classe étant compilée séparément. commence l'exécution en chargeant (loading) la classe contenant la méthode main. Ce travail de chargement est assuré par le ClassLoader qui opère à la demande ou de façon anticipée en pré chargeant certaines classes. La deuxième étape est le linking ou édition de liens qui se divise en trois phases : - vérification des contraintes de sécurité et de sémantique - préparation de l'espace d'adressage : allocation et initialisation des zones mémoires, - résolution des références non satisfaites. Cette phase peut entraîner de nouveaux chargements. Ceux-ci peuvent être faits immédiatement ou seulement à l'appel de la référence, suivant la technique du lazy linking. Un thread est créé pour exécuter la méthode main. La compilation à la volée (just in time ou JIT) consiste à traduire le byte code en langage machine au fur et à mesure de son décodage, après la phase de vérification. Cette technique peut diminuer d'un facteur 10 le temps de traitement du byte code qui n'est plus interprété, mais compilé. ENST Dép. INFRES 145 ENST Dép. INFRES 146
21 Les instructions De la JVM Les fichiers contenant du bytecode peuvent être désassemblés grâce à l'utilitaire javap. Rappel!: le bytecode est rangé dans l espace des méthodes Par exemple pour le fichier suivant : public class HelloWorld { public static void main(string args[]) { int i; for ( i=0 ; i<10 ; i++) ; System.out.println(" Hello world, i = " + i); } } $ javac HelloWorld.java $ java HelloWorld Hello world, i = 10 $ javap -c HelloWorld 0 iconst_0 # mettre 0 sur la pile 1 istore_1 # vider la pile dans la # première variable 2 goto 8 5 iinc 1 1 # ajouter 1 à la première variable # (on ne peut pas incrémenter # directement sur la pile) 8 iload_1 # empiler la premiere variable 9 bipush 10 # mettre 10 sur la pile 11 if_icmplt 5 # comparer les deux valeurs en sommet de pile 36 return ENST Dép. INFRES 147 ENST Dép. INFRES 148
22 Bytecode!: exemple (1) // Gestion de la machine a pile Java // Pour desassembler et obtenir le bytecode, utiliser la commande : // javap -c -verbose Demo1 > Demo1.bc public class Demo1 { public static void main(string[] args) { System.out.println("Coucou!"); // GestionPile(); } public void GestionPile() { int Var1, Var2, Var3, Var4, Var5, Var6; // Pour voir les differents types de load Var1 = 2; Var2 = 7; Var3 = 200; Var4 = ; // est une GROSSE constante... // Arithmetique sur la pile Var5 = Var1 + Var4; // Gestion des resultats intermediaires Var5 = 3*( (Var1/Var2) - 2/(Var4 + Var5) ); Var1++; Var2 <<= 3; // Pour voir... Var6 = 2*(Var1 = 4); // Appel de methode Var3 = Ajouter(Var1, Var2, -1); } public int Ajouter(int x, int y, int z) { int Somme; Somme = x + y + z; return Somme; } } ENST Dép. INFRES 149 ENST Dép. INFRES 150
23 Bytecode!: exemple (2) Le début du fichier et la fonction main en byte code : Compiled from Demo1.java public class Demo1 extends java.lang.object { public Demo1(); /* Stack=1, Locals=1, Args_size=1 */ public static void main(java.lang.string[]); /* Stack=2, Locals=1, Args_size=1 */ public void GestionPile(); /* Stack=5, Locals=7, Args_size=1 */ public int Ajouter(int, int, int); /* Stack=2, Locals=5, Args_size=4 */ } Method Demo1() 0 aload_0 1 invokespecial #1 <Method java.lang.object()> 4 return Method void main(java.lang.string[]) 0 getstatic #2 <Field java.io.printstream out> 3 ldc #3 <String "Coucou!"> 5 invokevirtual #4 <Method void println(java.lang.string)> 8 return ENST Dép. INFRES 151 ENST Dép. INFRES 152
24 Bytecode!: exemple (3) La fonction GestionPile en byte code : Method void GestionPile() 0 iconst_2 /* push constante 2 */ 1 istore_1 /* Rangement dans la variable num. 1 */ 2 bipush 7 /* byte integer push */ 4 istore_2 /* Rangement dans la variable num. 2 */ 5 sipush 200 /* short integer push */ 7 istore_3 /* Rangement dans la variable num. 3 */ 8 ldc #5 <Integer > /* CREATION et push de la cste */ 10 istore 4 12 iload_1 13 iload 4 15 iadd 16 istore 5 /* 12 a 16 : Var5 = Var1 + Var4; */ 18 iconst_3 19 iload_1 20 iload_2 21 idiv /* (Var1/Var2) */ 22 iconst_2 23 iload 4 25 iload 5 27 iadd /*(Var4 + Var5) */ 28 idiv 29 isub 30 imul /* 3*( (Var1/Var2) - 2/(Var4 + Var5) ) */ 31 istore 5 33 iinc 1 1 /* INSTRUCTION SPECIALE Var1++; */ 36 iload_2 37 iconst_3 38 ishl 39 istore_2 40 iconst_2 41 iconst_4 42 dup 43 istore_1 44 imul 45 istore 6 47 aload_0 48 iload_1 49 iload_2 50 iconst_m1 /* push constante -1 */ 51 invokevirtual #6 <Method int Ajouter(int, int, int)> 54 istore_3 55 return ENST Dép. INFRES 153 ENST Dép. INFRES 154
25 Bytecode!: exemple (4) La fonction Ajouter en Java!: public int Ajouter(int x, int y, int z) { int Somme; Somme = x + y + z; return Somme; } Le byte code correspondant!: Method int Ajouter(int, int, int) 0 iload_1 1 iload_2 2 iadd 3 iload_3 4 iadd 5 ireturn Rappel!: l appel à la méthode en Java et byte code: // Appel de methode Var3 = Ajouter(Var1, Var2, -1); 51 invokevirtual #6 <Method int Ajouter(int, int, int)> 54 istore_3 ENST Dép. INFRES 155 ENST Dép. INFRES 156
26 Bytecode!: Optimisations Interpréter le code est très pénalisant, par exemple dans le cas des boucles!: on refait la même opération n fois. D où l interêt de la compilation à la volée. Compilation à la volée (Just in time compilation) Dans ce cas, la JVM compile le bytecode en code directement exécutable par le processeur au lieu de l interprèter. Cette option est utilisée par défaut sur les stations Sun, on peut la désactiver ENST Dép. INFRES 157 ENST Dép. INFRES 158
27 Plan 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 ENST Dép. INFRES 159 ENST Dép. INFRES 160
28 La! gestion des threads Rien n est dit sur l ordonnancement des threads dans la spécification de la JVM. Changement de contexte si!: - le courant sort de l état runnable, se bloque ou se termine - yield passe la main au suivant de même priorité, ou au premier de priorité immédiatement inférieure - un plus prioritaire devient runnable ENST Dép. INFRES 161 ENST Dép. INFRES 162
29 La! gestion Des priorités Les priorités sont numérotées 1(min) à 10 (max), défaut!: 5. Un thread hérite de la priorité de son créateur setpriority() modifie la priorité - paramètres!:thread.min_priority, Thread.MAX_PRIORITY, Thread.NORM_PRIORITY Pour setpriority, on trouve!: Every thread has a priority. Threads with higher priority are executed in preference to threads with lower priority. ENST Dép. INFRES 163 ENST Dép. INFRES 164
30 La! gestion Mémoire Pour les threads Gestion de la mémoire pour les threads!: leurs piles sont généralement allouées sur le tas, à chaque thread est associé un compteur ordinal. Pile Compteur ordinaux T1 T2 T3 T1 frame frame frame T2 T3 frame frame frame frame frame frame Au démarrage d un thread, la JVM lui associe une pile. A chaque invocation de méthode est associée une «!frame!». Cette frame contient les paramètres d appel (les objets sont toujours passés par référence), les résultats intermédiaires, des informations de gestion (exceptions, ) A la fin de la méthode, la frame est dépilée, la frame suivante devient la «!current frame!». La structure de données qui implémente cette pile peut être contiguë ou non, un tas ou une pile, cela dépend de l implémentation ENST Dép. INFRES 165 ENST Dép. INFRES 166
31 Synchronisation!: Opérations Sur les long et double, volatile Les opérations sur des variables du type double ou long peuvent être traitées comme si ces variables étaient implantées sur deux mots de 32 bits. Les opérations (même les affectations) sur les long et double peuvent donc ne pas être atomiques. Pour assurer cette atomicité il faut les déclarer!: volatile double volatile long Bien sûr, si des variables partagées du type long ou double sont dans des zones synchronized, le problème ne se pose pas. D où l utilité de toujours gérer correctement (c est-à-dire en utilisant des outils de synchronisation) l accès aux ressources partagées. ENST Dép. INFRES 167 ENST Dép. INFRES 168
32 Synchronisation!: Utilisation de Synchronized A chaque objet est associé un verrou qui est pris lors de l entrée dans une méthode ou une région de code qualifiée de synchronized. synchronized doit être utilisé pour gérer tout accès à des variables partagées par plusieurs thread, y compris les affectations. Attention à l utilisation de synchronized sur une méthode static : on utilise le verrou qui gère l accès à la classe! ENST Dép. INFRES 169 ENST Dép. INFRES 170
33 Plan 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 ENST Dép. INFRES 171 ENST Dép. INFRES 172
34 Optimisations Suivi et traces!: java -verbose:gc -Xprof Xrunhprof Vérifier la portée des objets (scope) Attention à l utilisation des outils de synchronisation (granularité) Utiliser StringBuffer plutôt que String pour manipuler des chaînes de caractères Utiliser des méthodes statiques!: int i = new Integer(Valeur).intValue()!; int i = Integer.parseInt(Valeur); Allocation des variables : - rapide pour les variables locales (restent sur la pile) - lente sur le tas!: variables statiques et variables d instances Il vaut mieux créer un tableau statique de 2000 octets que d en allouer à chaque appel d une méthode fréquemment appelée Vector et WrappedArrayList sont synchronisées, pas ArrayList ENST Dép. INFRES 173 ENST Dép. INFRES 174
35 Optimisations Exemple!: le type String réutilise et partage les String parce qu elles sont des constantes et donc thread-safe. La classe String gère un pool de String s: si la chaîne existe déjà, la JVM renvoie une référence sur cette chaîne, sinon elle en créé une nouvelle. Mais la création par new ignore ce mécanisme utiliser new pour une String que si nécessaire. Dans ce cas, la chaîne est allouée sur le tas (pas sur une JVM embarquée). Exemple!: String Chaine1 = "Bonjour"; String Chaine2 = "Bonjour"!; String Chaine3 = new String("Bonjour")!; Chaine2 == Chaine1!;! renvoie vrai (pointeurs égaux) Chaine3 == Chaine1!;! renvoie faux. Rappel : == vérifie les références, equals() vérifie les contenus! ENST Dép. INFRES 175 ENST Dép. INFRES 176
36 String et StringBuffer Les String sont des constantes chaînes, StringBuffer des variables. La concaténation est plus efficace avec StringBuffer qu avec String ENST Dép. INFRES 177 ENST Dép. INFRES 178
37 Plan 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 ENST Dép. INFRES 179 ENST Dép. INFRES 180
38 Les JVM embarquées Contraintes sur le matériel!: - taille de la mémoire, vitesse du processeur, consommation - capacités graphiques réduites Contraintes logicielles!: - ordonnancement, synchronisation - fonctionnement du GC - gestion des E/S, des interruptions - chargement dynamique des classes ENST Dép. INFRES 181 ENST Dép. INFRES 182
39 ENST Dép. INFRES 183
Analyse statique de programmes Typage et analyse statique au sein de Java
Analyse statique de programmes Typage et analyse statique au sein de Java Master Professionnel Informatique spécialité FSIL/FSI Jean-Marc Talbot jean-marc.talbot@lif.univ-mrs.fr Aix-Marseille Université
Mieux programmer en Java
Mieux programmer en Java Peter Haggar Éditions Eyrolles ISBN : 2-212-09171-0 2000 PARTIE 1 l exécution de l instruction return, cependant, le contrôle est transféré au bloc finally en // 2. Cela provoque
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
Machines virtuelles. Brique ASC. Samuel Tardieu sam@rfc1149.net. Samuel Tardieu (ENST) Machines virtuelles 1 / 40
Machines virtuelles Brique ASC Samuel Tardieu sam@rfc1149.net École Nationale Supérieure des Télécommunications Samuel Tardieu (ENST) Machines virtuelles 1 / 40 Machines virtuelles La compilation peut
Licence 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
La 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
Java embarqué. Module I500 de L3 Benoît Miramond
Java embarqué Module I500 de L3 Benoît Miramond Problématique Quel rapport entre Java et l architecture? Java travail sur un modèle d exécutif différent des langages compilés => Étude des modèles exécutif
Synchro 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
Les tâches et la synchronisation en langage Java
Les tâches et la synchronisation en langage Java Les threads, les verrous, les sémaphores et les moniteurs en Java D après les cours de D. Genthial et B. Caylux Langage Java Threads et synchronisation
Info0604 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
NFP 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
Mode d emploi pour la P-machine utilisée lors des TPs et des projets du cours INFO010 Théorie des langages et de la compilation.
Mode d emploi pour la P-machine utilisée lors des TPs et des projets du cours INFO010 Théorie des langages et de la compilation. Sébastien COLLETTE et Gilles GEERAERTS 1 Introduction Ce document décrit
Programmer 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
Année 2008-2009. Les threads Java. Nicolas Baudru mél : nicolas.baudru@esil.univmed.fr page web : nicolas.baudru.perso.esil.univmed.
Année 2008-2009 Les threads Java Nicolas Baudru mél : nicolas.baudru@esil.univmed.fr page web : nicolas.baudru.perso.esil.univmed.fr 1 Présentation du problème Revenons quelques instants à nos animaux.
Eléments de syntaxe du langage Java
c jan. 2014, v3.0 Java Eléments de syntaxe du langage Java Sébastien Jean Le but de ce document est de présenter es éléments de syntaxe du langage Java : les types primitifs, les opérateurs arithmétiques
Plan. Environnement Client/Serveur. Cours 6 Rappels Java (suite) Appel de méthode à distance. Utilité. static
Plan Environnement Client/Serveur Cours 6 Rappels Java (suite) Appel de méthode à distance kn@lri.fr http://www.lri.fr/~kn 1 Rappels sur les systèmes d'exploitations / Communication par mémoire partagée
JAVA - Compléments du cours 9
JAVA - Compléments du cours 9 Nicolas Baudru Année 2008-2009 Exercice 1 (Création de threads) En Java, il existe deux méthodes pour créer des threads. La première étend la classe Thread : class MonThread
Avant de programmer en Java DOS Set Path=C:\JDK\bin Path=C:\JDK\bin C:\JDK\bin Set Path=%Path%;C:\JDK\bin C:\JDK\bin C:\JDK\
Exercices corrigés de programmation OO Java Préparés par : Mlle Imene Sghaier Année Académique : 2006-2007 Premiers Pas I. Avant de programmer en Java Le JDK de Sun (Java Development Kit) est l outil essentiel
La programmation concurrente
La programmation concurrente Jean-Ferdy Susini Maître de Conférences - CNAM Département Informatique Sources : Android Developpers, Wikipedia Paris, 06/05/2015 Architecture matérielle 2 Considérons l architecture
Cours 3 : The Dalvik VM Specification. Damien MASSON d.masson@esiee.fr
Androïd Cours 3 : The Dalvik VM Specification Damien MASSON d.masson@esiee.fr http://igm.univ-mlv.fr/~masson/teaching/android/ 1 er mars 2011 Buts du cours et Références Buts : Pourquoi Google n a pas
Java - Historique. Une introduction à Java. Premier exemple. Aperçu de Java. Processus d obtention d un exécutable. Compilation/interprétation
Java - Historique Une introduction à Java IFT 287 (Semaine 1) UNIVERSITÉ DE SHERBROOKE 1 Développé par Sun Microsystems en 1994 Inventeur James Gosling (canadien!) Objectif langage sûr (fortement typé)
CCI - Initiation à Java. E.Coquery emmanuel.coquery@liris.cnrs.fr
CCI - Initiation à Java E.Coquery emmanuel.coquery@liris.cnrs.fr Présentation du langage Outline 1 Présentation du langage 2 Types de données primitifs 3 Objets Présentation du langage Un langage orienté
Plan. Tableaux. Utilité. Définition. Exemples. Déclaration d un tableau
Plan Tableaux Université de Nice - Sophia Antipolis Richard Grin Version 1.0.4 25/11/10 Définition Déclaration d un tableau Création d un tableau Utilisation d un dun tableau Tableau des paramètres de
Gestion de la mémoire
Chapitre 9 Gestion de la mémoire Durant l exécution d un programme, les éléments manipulés par le programme sont stockés dans différents types de mémoire. La pile d exécution contient des éléments dont
Mémoire virtuelle. Généralités
Mémoire virtuelle Généralités La pagination pure - Conversion d adresses virtuelles en adresses physiques - Table des pages à plusieurs niveau et table inversée - Algorithmes de remplacement de page -
INTRODUCTION 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
J2SE 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
2 ème partie : Programmation concurrente multi-thread
2 ème partie : Programmation concurrente multi-thread TC-INFO-ASR4 Françoise Baude Université de Nice Sophia-Antipolis UFR Sciences Département Informatique baude@unice.fr web du cours : www-mips.unice.fr/~baude
Une introduction au langage C++ Marc Jachym, Lurpa
Une introduction au langage C++ Marc Jachym, Lurpa Janvier 2008 À l origine, le langage C Langage procédural créé dans les années 1970 aux laboratoires Bell (ATT : télécoms américains) en vue d écrire
Une 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é)
Précis de vocabulaire Orienté Objet
Dernière Mise à jour : Mars 2007 Précis de vocabulaire Orienté Objet 1 Questions Expliquer et donner un exemple pour chacun des concepts suivants 1. Qu'est-ce qu'un objet? 2. Qu'est-ce qu'une classe? 3.
Cours 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/
Résumé Introduction Programmation Java
Résumé Introduction Programmation Java Concepts Un programme : séquence, test conditionnel, boucles. Objets : Les objets Java modélisent les objets d un problème donné Classe : Les objets sont crées à
Programmation Orientée Objet Java
Programmation Orientée Objet Java Bertrand Estellon Département Informatique et Interactions Aix-Marseille Université 29 octobre 2015 Bertrand Estellon (DII AMU) Programmation Orientée Objet Java 29 octobre
Les tableaux. Programmation Orientée Objet Java. Références et Garbage Collector. Les tableaux
Les tableaux Déclaration d une variable de type référence vers un tableau : Programmation Orientée Objet Bertrand Estellon Département Informatique et Interactions Aix-Marseille Université 29 octobre 2015
Université de Bourgogne - UFR Sciences et Technique - Programmation objet - LPSIL - 2013
Nom : Prénom : Contrôle continu n 4 Programmation objet Vous devez répondre dans les cadres aux questions posées. Documents de cours et notes personnelles autorisés. Téléphones portables, ordinateurs et
07 - Mémoire. Morgan Barbier morgan.barbier@unicaen.fr L2 S4 2012/2013
07 - Mémoire Morgan Barbier morganbarbier@unicaenfr L2 S4 2012/2013 1 Introduction Problèmatique Multitâches : L OS moderne permet d exécuter plusieurs tâches en même temps Chacune de ses tâches possèdent
Un 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
Architecture des ordinateurs
Architecture des ordinateurs Cours 4 5 novembre 2012 Archi 1/22 Micro-architecture Archi 2/22 Intro Comment assembler les différents circuits vus dans les cours précédents pour fabriquer un processeur?
Structure 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
Auto-é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
Moniteurs, Java, Threads et Processus
Moniteurs, Java, Threads et Processus 1 Une vue orientée-objet de la mémoire partagée On peut voir un sémaphore comme un objet partagé accessible par deux méthodes : wait et signal. L idée du concept de
Programmation multitâches avec les Threads
Programmation multitâches avec les Threads A. Introduction A.1. Programmation multitâche Tous les systèmes d'exploitation actuels ont la possibilité d'effectuer plusieurs tâches en simultané. En effet,
Plan 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
Programmation Bas Niveau
Programmation Bas Niveau Basé en grande partie sur les notes de Etienne Payet et Fausto Spoto 1 Université de La Réunion FST - L2 Info Introduction 2 Module Machines virtuelles (Java), bytecode, etc. 30h
Claude Kaiser Machine virtuelle et environnement utilisateur SRI_B CHAPITRE 1
CHAPITRE 1 FOURNIR À L'UTILISATEUR UNE MACHINE VIRTUELLE ET UN ENVIRONNEMENT D'EXÉCUTION DE PROGRAMMES Plan ENVIRONNEMENT DE TRAVAIL ADAPTÉ AU BESOIN DE L'UTILISATEUR Fonctions de l'environnement d'exécution
JAVA Première approche
Année 2008-2009 JAVA Première approche Nicolas Baudru mél : nicolas.baudru@esil.univmed.fr page web : nicolas.baudru.perso.esil.univmed.fr 1 Qu'est ce que Java? C'est le nom d'une technologie mise au point
Cours client-serveur Web : Java et RMI (Remote Method Invocation)
Cours client-serveur Web : Java et RMI (Remote Method Invocation) 1 Java: Rappel sur les threads Cycle de vie d un thread (1) Né -> prêt appel de la méthode start du thread Prêt Exécution Distribution
Principes de la programmation impérative
Séquence d instructions Variables et types Types élaborés Procédures, arguments Gestion de la mémoire Langage compilé, interprété Principes de la programmation impérative Séquence d instructions Variables
Cours 1. Contenu du cours : " Premières applications. " Compilation, Exécution, Chemin. " Affichage et saisie. " Types de données. " Flux de contrôle
Cours 1 1 Contenu du cours : " Premières applications " Compilation, Exécution, Chemin " Affichage et saisie " Types de données " Flux de contrôle " Applets " Arrays " OO de base Edition Le fichier texte
Syntaxe du langage JAVA. Philippe Roose (IUT Bayonne) Olivier Dedieu (INRIA)
Syntaxe du langage JAVA Philippe Roose (IUT Bayonne) Olivier Dedieu (INRIA) Structure du langage Les types primitifs boolean(true/false), byte (1 octet), char (2 octets), short (2 octets), int (4 octets),
Structure d un programme et Compilation Notions de classe et d objet Syntaxe
Cours1 +Cours 2 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
Généralités Composants élémentaires d'un programme Instructions simples. JL Damoiseaux - Dpt R&T
JAVA - I Généralités Composants élémentaires d'un programme Instructions simples 2 JAVA? Un langage de programmation (orienté objets) Une architecture basée sur une Machine Virtuelle Un ensemble très important
Notions de langage machine
Notions de langage machine 18 décembre 2009 Rappels et introduction Architecture de Van Neumann : Processeur = UC + UAL Mémoire interne au processeur = les registres (soit seulement l accumulateur, soit
Dr. M.W. Youssef Systèmes d exploitation Avancées 1ING ISI - 2009
Institut Supérieur d Informatique Chapitre 02 Synchronisation des processus Dr. Mohamed-Wassim YOUSSEF 2009 [www.wassimyoussef.info] Systèmes d exploitation avancées 1 ING ISI 1 ére année Ingénieur en
Listes de personnes et calculatrice polonaise inverse en Java
Listes de personnes et calculatrice polonaise inverse en Java Université Paris Sud Motivation Le but de cet exercice est de manipuler les listes chaînées et les piles et de voir leur application en analyse
Projet 1 ENS Lyon L3IF
Projet 1 ENS Lyon L3IF Génération de code Sébastien Briais 8 janvier 2008 Dans cette partie, vous allez devoir implémenter le générateur de code pour l émulateur DLX risc-emu. À rendre pour le 18 janvier
Introduction à la Programmation 1
Introduction à la Programmation 1 Séance de cours/td Université Paris-Diderot Objectifs: Découverte du type String. Comprendre qu il y a des types différents. Maîtriser les expressions booléennes dans
Programmation 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
Chapitre V : La gestion de la mémoire. Hiérarchie de mémoires Objectifs Méthodes d'allocation Simulation de mémoire virtuelle Le mapping
Chapitre V : La gestion de la mémoire Hiérarchie de mémoires Objectifs Méthodes d'allocation Simulation de mémoire virtuelle Le mapping Introduction Plusieurs dizaines de processus doivent se partager
La plate-forme Java RMI
La plate-forme Java RMI Frank Singhoff Bureau C-202 Université de Brest, France Lab-STICC/UMR 3192 singhoff@univ-brest.fr UE systèmes à objets répartis, Université de Brest Page 1/25 Sommaire 1. Le modèle
Modèle client-serveur
Modèle client-serveur Daniel Hagimont IRIT/ENSEEIHT 2 rue Charles Camichel - BP 7122 31071 TOULOUSE CEDEX 7 Daniel.Hagimont@enseeiht.fr http://hagimont.perso.enseeiht.fr 1 Plan Principes généraux Modèle
Introduction à la Programmation 1
Introduction à la Programmation 1 Séance 7 de cours/td Université Paris-Diderot Objectifs: Savoir écrire un programme en entier (structure du programme avec une procédure main et des déclarations de fonctions,
C++ / MC-II1 - Cours n o 3 Allocation Mémoire et Constructeurs
C++ / MC-II1 - Cours n o 3 Allocation Mémoire et Constructeurs Sebastien.Kramm@univ-rouen.fr IUT GEII Rouen 2010-2011 S. Kramm (IUT Rouen) MCII1 - Cours 3 2010-2011 1 / 47 Sommaire 1 Rappels de C et définitions
Chapitre 2. Classes et objets
Chapitre 2: Classes et Objets 1/10 Chapitre 2 Classes et objets Chapitre 2: Classes et Objets 2/10 Approche Orientée Objet Idée de base de A.O.O. repose sur l'observation de la façon dont nous procédons
Cours 4. - Créer des animations : la classe Thread et l'interface Runnable - Quelques composants supplémentaires : le choix dans une liste
Cours 4 - Créer des animations : la classe Thread et l'interface Runnable - Quelques composants supplémentaires : le choix dans une liste JComboBox et JList F. Gayral 1 Rappel : multi-tâches multi-tâches
PRESENTATION DE JAVA. Qu est-ce que java? Les caractéristiques du langage java Les outils Les API Références. Software Associates International
PRESENTATION DE JAVA Qu est-ce que java? Les caractéristiques du langage java Les outils Les API Références 1 Qu est-ce que java? Un langage de programmation orienté objets Une architecture de Virtual
Introduction au langage Java
Introduction au langage Java 1 / 24 1 Vue générale La technologie Java Le langage Java La machine virtuelle Java Résumé Plan 2 Hello World Prérequis Premier programme : 3 étapes Résumé 3 HelloWorld en
as 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
Héritage, et quelques petits mots-clés de Java
Héritage, et quelques petits mots-clés de Java Bilan de la séance du 3 février. 1 Champs d instance, champs de classe La situation usuelle pour les attributs et les méthodes est la suivante : La classe
TP, première séquence d exercices.
TP, première séquence d exercices. Benoît Valiron benoit.valiron@lipn.univ-paris13.fr 7 novembre 2010 Introduction Vous écrirez les réponses aux questions courtes sur une feuille à rendre à la fin de la
PROB Introduction au langage JAVA
PROB Introduction au langage JAVA EPFC ULB 1 BACHELIER en INFORMATIQUE de Gestion PRMT(1) 120p. LAPR(2) 120p. PR(1) PROB(10) 120p. PR(1) PRDV(4) 40p. PR(2 ou 9) COFI(20) 60p. GBDR(5) 120p. LAOG(9) 120p.
Chargement de processus Allocation contigüe Allocation fragmentée Gestion de pages. Gestion mémoire. Julien Forget
Julien Forget Université Lille 1 École Polytechnique Universitaire de Lille Cité Scientifique 59655 Villeneuve d Ascq GIS 3 2011-2012 1 / 46 Rôle du gestionnaire de mémoire Le gestionnaire de mémoire a
Introduction aux systèmes d exploitation
Introduction aux systèmes d exploitation Le système d exploitation est un ensemble de logiciels qui pilotent la partie matérielle d un ordinateur. Les principales ressources gérées par un système d exploitation
Modèle client-serveur
Modèle client-serveur Daniel Hagimont IRIT/ENSEEIHT 2 rue Charles Camichel - BP 7122 31071 TOULOUSE CEDEX 7 Daniel.Hagimont@enseeiht.fr http://hagimont.perso.enseeiht.fr Remerciements Michel Riveill 1
Tableaux (introduction) et types de base
Tableaux (introduction) et types de base A. Motivation..................................................... 4 B. Les tableaux.................................................... 5 C. Construction des tableaux.......................................
Instructions assembleur
Instructions assembleur 0001011011110110 0001011101101101 10001001 Instruction vue par le programmeur assembleur ou instruction élémentaire cible d'un compilateur Réalise une modification de l'état interne
Récupération automatique de la
Récupération automatique de la mémoire 1 Plan 1. La gestion du tas. 2. Marquage et balayage. 3. Comptage de références. 4. Récupération par copie. 5. Compléments. 2 Problématique Le code exécutable généré
Pour 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
Polymorphisme. Programmation Orientée Objet. Jean-Christophe Routier Licence mention Informatique Université Lille 1
Polymorphisme Programmation Orientée Objet Jean-Christophe Routier Licence mention Informatique Université Lille 1 Université Lille 1 - Licence Informatique Programmation Orientée Objet 1 des méthodes
Système M1. Chapitre 3 : Gérer la communication et la synchronisation inter-tâches. J.-F. Pradat-Peyre & E Hyon
Chapitre 3 : Gérer la communication et la synchronisation inter-tâches 1 Plan du cours Introduction aux problèmes de synchronisation Exemple de problèmes Section critique et verrous Exclusion Mutuelle
Le «thread local storage» et son utilisation
Résumé Les allocations mémoire sont généralement plus coûteuses que d ordinaire en environnement multi-thread. En effet, la majorité des algorithmes d allocation en usage dans les systèmes d exploitation
Programmation concurrente en java
Programmation concurrente en java M. Belguidoum Université Mentouri de Constantine Département Informatique M. Belguidoum (UMC) Programmation concurrente 1 / 29 Plan 1 Introduction 2 Création d'un thread
2001-2002. UFR Mathématiques de la Décision. Première Année de DEUG Sciences et Technologie mention MASS. Informatique. Volume I.
2001-2002 UFR Mathématiques de la Décision Première Année de DEUG Sciences et Technologie mention MASS Informatique Volume I Fabrice Rossi c Fabrice Rossi, 1997-2002 Conditions de distribution et de copie
Une classe est une sorte de type de données définie par le programmeur Variables peuvent être de type classe
Classe, Objet Variables locales Niveaux de visibilité (Encapsulation) Attributs et Méthodes Statiques Surcharge des Méthodes Transmission des Paramètres Paquetage Classes pour les types de base POO 1 Une
Chap. III : Le système d exploitation
UMR 7030 - Université Paris 13 - Institut Galilée Cours Architecture et Système Le système d exploitation (ou O.S. de l anglais Operating System ) d un ordinateur est le programme qui permet d accéder
Java - 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)
Génération de code : langages objets Gestion mémoire 2 novembre 2011
Génération de code : langages objets Gestion mémoire 2 novembre 2011 1 Compilation d un langage objet Représentation des classes et des objets Héritage multiple Appartenance à une classe 2 Environnement
Cours 2 : The Java VM Specification. Damien MASSON d.masson@esiee.fr. 28 février 2011
Androïd Cours 2 : The Java VM Specification Damien MASSON d.masson@esiee.fr http://igm.univ-mlv.fr/~masson/teaching/android/ 28 février 2011 Buts du cours et Références Ce cours présente le fonctionnement
TP Java RMI. Alexandre Denis Alexandre.Denis@inria.fr. Inria Bordeaux Sud-Ouest France ENSEIRB PG306
TP Java RMI Alexandre Denis Alexandre.Denis@inria.fr Inria Bordeaux Sud-Ouest France ENSEIRB PG306 Paradigme RMI RMI (Remote Method Invocation) RPC orientés objet (encapsulation, héritage,...) objet :
Introduction au Java Development Kit Et quelques instructions en Java. 1 Création des répertoires d accueil des programmes Java
HLIN406 - Janvier 2015 Le Java Development Kit offre un ensemble d outils de développement d applications Java. Pour utiliser ces outils, JDK ne propose pas d interface utilisateur, on doit donc écrire
Objectif du cours. Bases de la programmation. Plan de cette partie
Objectif du cours Bases de la programmation Université de Nice - Sophia Antipolis Richard Grin Version 1.2.5 24/9/11 http://deptinfo.unice.fr/~grin Introduction à la programmation orientée objet pour pouvoir
Types et performances des processeurs
Types et performances des processeurs Laboratoire de Systèmes Logiques Structure d un ordinateur contrôle processeur traitement séquenceur registres mémoire entrées/sorties micromémoire opérateurs bus
Objets distribués et Appel de Méthodes à Distance 2009-2010
Objets distribués et Appel de Méthodes à Distance 2009-2010 1 Objectif : construire une application où différents modules peuvent être situés sur des machines différentes, en utilisant un modèle à objets
Programmation Orientée Objet avec JAVA
Programmation Orientée Objet avec JAVA Présenté par Abdoul Aziz Ciss Docteur en Cryptologie, Consultant ITSec Dept GIT EPT Email: aaciss@ept.sn Web : www.alekciss.com Tel: 77 451 92 95 Plan 1. Introduction
Introduction aux Machines Virtuelles avec VMKit
Introduction aux Machines Virtuelles avec Ingénieur :, Responsables : Gaël Thomas, Gilles Müller EQUIPE REGAL LIP6 INRIA (Paris/France) un substrat de machine virtuelle : a substrate for Managed Runtime
Introduction à l Informatique
Introduction à l Informatique. Généralités : Etymologiquement, le mot informatique veut dire «traitement d information». Ceci signifie que l ordinateur n est capable de fonctionner que s il y a apport
Traduction des Langages : Le Compilateur Micro Java
BARABZAN Jean-René OUAHAB Karim TUCITO David 2A IMA Traduction des Langages : Le Compilateur Micro Java µ Page 1 Introduction Le but de ce projet est d écrire en JAVA un compilateur Micro-Java générant
JVM. RMI - couche de référence. RMI - couche de transport TCP/IP
Chapitre 9 Dans ce chapitre nous abordons le mécanisme RMI (Remote Method Invocation) permettant le développe ment des systèmes répartis. Nous expliquerons comment les classes d un serveur peuvent être
ASSEMBLAGE ET ÉDITION DES LIENS
ASSEMBLAGE ET ÉDITION DES LIENS Mewtow 11 novembre 2015 Table des matières 1 Introduction 5 2 La chaine d assemblage 7 2.1 Résolution des symboles.............................. 7 2.2 Relocation.....................................