-
Accueil
- ›
-
Formations developpement et methodes
- ›
-
JAVA SE Optimisations de code Java
Formation
JAVA SE Optimisations de code Java
- Domaine
- DEVELOPPEMENT et METHODES
- Objectifs
- A la suite de la formation le stagiaire sera apte à évaluer la consommation des ressources engendrées par une modélisation et par l'implémentation de cette dernière. L'étude des mécanismes de bas niveaux de la JVM permettra de mieux ressentir les différents concepts présentés. Des outils graphiques de monitoring et de profiling d'applications Java seront de plus présentés.
- Durée
- 3 jours (
21 heures)
- Participants
- Tous développeurs Java, et plus particulièrement ceux spécialisés dans le développement d'applications critiques, temps réel ou fonctionnant en environnement embarqués.
- Pré-requis
- Afin de suivre ce cours, le stagiaire devra déjà connaître les bases du langage Java
- Lieu de formation
- Notre centre de formation à Grenoble
- Notre centre de formation à Moirans
- Notre centre de formation à Sophia Antipolis
- Ou sur votre site en formation intra
Programme de formation
JAVA SE Optimisations de code Java
- Quelques rappels fondamentaux
- L'environnement J2SE (Java 2 Standard Edition) (Concepts fondamentaux : ClassLoader, JIT, GC, Gestionnaire d'exceptions, ..., JVMPI (Java Virtual Machine Profiling Interface), Quelques outils du J2SE : javap, ...)
- Notion de byte code (Utilisation du désassembleur javap, Notions de pile et de tas (Stack & Heap), Mécanisme de déclarations : variables locales et attributs, Appels de méthodes en assembleur)
- Quelques considérations sur les performances (Temps d'exécution VS taille de l'exécutable
- Développement d'agents JVMPI
- Concepts fondamentaux de JVMPI (Les différentes versions l'interface JVMPI, Les évènements JVMPI, Prises de mesure de temps et applications multithreadées)
- Codage d'agents JVMPI (Traquer l'activité du ClassLoader, Traquer l'activité en termes d'allocations dynamiques, Traquer l'activité en termes d'appels de méthodes)
- Guide lines de programmation
- Encapsulation VS performance (Coût d'invocation de getter/setter, Optimisation des temps de développement)
- Fonctionnement de l'instruction switch
- Limitation d'instances temporaires (Utilisation des chaînes de caractères)
- Utilisation des collections Java (Choisir les bons algorithmes, Collection synchronisées ou non (Vector vs ArrayList, ...), Les différentes techniques de parcours d'une collection)
- Utilisation de tableaux Java typés (Accès indexés aux valeurs, Traitements des valeu
- Le garbage collector (GC)
- Aspects fondamentaux (Tâches du garbage collector : libération et défragmentation, Les différents algorithmes utilisés)
- Fonctionnement du Garbage Collector de la JVM Hotspot (Sun Microsystems) (Monitorer l'activité du GC, Collectes mineures et collectes majeures)
- Paramétrage du Garbage Collector de la JVM HotSpot (Gestion de la taille des Heap (-Xmx, -Xms, -XX:NewRatio, -XX:SurvivorRatio, ...), Libération incrémentale des ressources, Utilisation multi-threadées du garbage collector)
- Recyclons les ressources de la JVM
- Utilisation d'un pool d'instances (Implémentation d'un pool d'instances, Utilisation d'un pool d'instances, Etude du comportement du GC via un agent JVMPI)
- Application multithreadées (Monitoring via JVMPI sur l'utilisation des threads, Le package java.util.concurrent, Utilisation de pool de threads)
- SoftReferences et WeakReferences
- Outils graphiques de monitoring et de profiling
- La JConsole (Présentation du modèle JMX (Java Monitoring eXtensions), Démarrage d'une JVM supportant le monitoring, Lancement et attachement de la JConsole, Les différentes possibilités de la JConsole)
- TPTP (Test and Performance Tool Platform) (Rappel sur l'utilisation de plugin Eclipse, Présentation du plugin TPTP, Test de détection de fuite de mémoire, Mesure de performances d'une application Java, Taux de couverture de code)