Formations Java
Détails :
Optimisations de code Java
Durée :
3 Jours
Objectif :
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 aussi présentés. L'accent sera mis sur les nombreux travaux pratiques proposés.
Prérequis :
Afin de suivre ce cours, le stagiaire devra déjà connaître les bases du langage Java.
Public :
Cette formation s'adresse aux développeurs Java.
Autres Informations :
Devis :
Si vous souhaitez être contacté et obtenir plus d'informations sur cette formation veuillez remplir notre formulaire de mise en relation.
>
Cursus :
Optimisations de code Java
    Quelques rappels fondamentaux
    • L'environnement Java SE (Java Standard Edition)
      • Concepts fondamentaux : ClassLoader, JIT, GC, Gestionnaire d'exceptions, ...
      • JVMTI (Java Virtual Machine Tools Interface)
      • Quelques outils du J2SE : javap, ...
    • Notion de byte code
      • Utilisation du désassembleur javap
      • Notions de pile et de tas (Stack et 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
      • Génie logiciel VS Performances

    Développement d'agents JVMTI
    • Concepts fondamentaux de JVMTI
      • Les différentes versions de l'interface JVMTI
      • Les évènements JVMTI
    • Codage d'agents JVMTI
      • 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
    • Utiliser correctement les Logger (Log4J, ...)
    • Fonctionnement de l'instruction switch
    • Limitation d'instances temporaires
    • Utiliser de manière efficace les chaînes de caractères
    • Utilisation des collections Java
      • Choisir les bons algorithmes face aux besoins
      • Collections synchronisées ou non (Vector vs ArrayList, ...)
      • Les différentes techniques de parcours d'une collection
      • Problématiques de l'autoboxing et du unboxing
    • Utilisation de tableaux Java typés
      • Accès indexés aux valeurs
      • Traitements des valeurs de types primitifs
    • Encapsulation VS performance

    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 (Oracle)
      • Monitorer l'activité du GC
      • Collectes mineures et collectes majeures
    • Comparaison Hotspot/OpenJ9
    • 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
    • Les évolutions du GC au fil des versions de Java

    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 JVMTI
    • Applications multi-threadées
      • Monitoring via JVMTI sur l'utilisation des threads
      • Le package java.util.concurrent
      • Utilisation de pool de threads
      • Gestion de la synchronisation de vos threads
    • SoftReferences et WeakReferences

    Outils graphiques de monitoring et de profiling
    • La JConsole
      • Présentation du modèle JMX (Java Monitoring eXtensions)
      • Lancement et attachement de la JConsole
      • Les différentes catégories d'informations collectées
    • Visual GC et GC Viewer
      • Les différences entre les deux outils
      • Analyses poussées de l'activité du GC
    • Java VisualVM
      • Présentation de l'outil
      • Profilling de type CPU
      • Profilling de type Memory
    • Autres outils de profilage
      • Utilisation du plugin Eclipse Memory Analyser Tool
      • JProfiler