IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Java Discussion :

Connaître les optimisations faites par la JVM


Sujet :

Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Modérateur
    Avatar de ToTo13
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Janvier 2006
    Messages
    5 793
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Santé

    Informations forums :
    Inscription : Janvier 2006
    Messages : 5 793
    Par défaut Connaître les optimisations faites par la JVM
    Bonjour,

    y a t-il un moyen de savoir si un code java a été optimisé par/pour la JVM ?

    Voilà comment j'en suis arrivé à me poser cette question :
    Je fais actuellement du traitement d'images en 3D. Mon image est représentée par un tableau 1D.
    Je fais un même traitement suivant les trois plans possibles (XY, XZ, YZ). Le code est exactement le même pour chaque plan (voir ci-dessous), je n'ai besoin que de modifier deux variables pour traiter différents plans, mais à l'arrivée chaque traitement fait EXACTEMENT le même nombre d'opérations/comparaisons/lectures/écritures.
    Seulement, le temps de traitement d'un plan par rapport à un autre peut aller du simple au triple.

    Code java : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    System.arraycopy(intbufferin, pos, intbufferout, pos, width) ;
    for (s=-1, p=pos-Param1 ; -sewidth <= s && 0 <= Param2+s ; s--, p-=Param1)
    	ArrayOperations.Maximum(intbufferin, p, intbufferout, pos, intbufferout, pos, width) ; // Simple maximum entre deux tableaux


    J'en déduis donc que le code qui traite plus rapidement un certain plan a dû recevoir une quelconque optimisation et j'aimerai savoir déterminer laquelle.


    Merci par avance...
    Consignes aux jeunes padawans : une image vaut 1000 mots !
    - Dans ton message respecter tu dois : les règles de rédaction et du forum, prévisualiser, relire et corriger TOUTES les FAUTES (frappes, sms, d'aurteaugrafe, mettre les ACCENTS et les BALISES) => ECRIRE clairement et en Français tu DOIS.
    - Le côté obscur je sens dans le MP => Tous tes MPs je détruirai et la réponse tu n'auras si en privé tu veux que je t'enseigne.(Lis donc ceci)
    - ton poste tu dois marquer quand la bonne réponse tu as obtenu.

  2. #2
    Expert éminent
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Billets dans le blog
    1
    Par défaut
    Salut,


    Attention que cela pourrait également être causé par le GC.
    Je ne sais pas si on peut voir les optimisations qui sont effectué, mais tu peux logger le passage du GC et les compilations avec les options -XX:+PrintGC -XX:+PrintCompilation.


    a++

  3. #3
    Membre Expert
    Avatar de eulbobo
    Homme Profil pro
    Développeur Java
    Inscrit en
    Novembre 2003
    Messages
    786
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Novembre 2003
    Messages : 786
    Par défaut
    Si tu veux voir si le compilateur a optimisé ton code, il n'y a pas 36 solutions : décompiler la classe et voir si elle est identique ou pas.
    Mais après, avec le système de JIT, c'est difficile de savoir quelles autres optimisations peuvent être réalisées à l'exécution...

    Clairement, je connais pas assez les méandres des optimisations de dernières minutes à l'exécution pour voir pourquoi tu as de telles différences à l'exécution...

  4. #4
    Modérateur
    Avatar de ToTo13
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Janvier 2006
    Messages
    5 793
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Santé

    Informations forums :
    Inscription : Janvier 2006
    Messages : 5 793
    Par défaut
    Citation Envoyé par adiGuba Voir le message
    Attention que cela pourrait également être causé par le GC.
    Je ne sais pas si on peut voir les optimisations qui sont effectué, mais tu peux logger le passage du GC et les compilations avec les options -XX:+PrintGC -XX:+PrintCompilation.
    Merci pour ta réponse, mais c'est peu vraisemblable dans mon cas, car toutes les opérations n'utilisent pas de mémoire supplémentaire. Une fois mon volume à traité lu et le volume résultat créé, aucune mémoire supplémentaire n'est utilisée. De plus ces deux volumes ne représentent que très peu de mémoire, je ne suis même pas à 5% de la mémoire disponible.
    Citation Envoyé par eulbobo Voir le message
    Si tu veux voir si le compilateur a optimisé ton code, il n'y a pas 36 solutions : décompiler la classe et voir si elle est identique ou pas.
    Mais après, avec le système de JIT, c'est difficile de savoir quelles autres optimisations peuvent être réalisées à l'exécution...
    Merci pour l'idée. Saurais tu comment "décompiler" efficacement ?
    Consignes aux jeunes padawans : une image vaut 1000 mots !
    - Dans ton message respecter tu dois : les règles de rédaction et du forum, prévisualiser, relire et corriger TOUTES les FAUTES (frappes, sms, d'aurteaugrafe, mettre les ACCENTS et les BALISES) => ECRIRE clairement et en Français tu DOIS.
    - Le côté obscur je sens dans le MP => Tous tes MPs je détruirai et la réponse tu n'auras si en privé tu veux que je t'enseigne.(Lis donc ceci)
    - ton poste tu dois marquer quand la bonne réponse tu as obtenu.

  5. #5
    Membre Expert
    Avatar de eulbobo
    Homme Profil pro
    Développeur Java
    Inscrit en
    Novembre 2003
    Messages
    786
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Novembre 2003
    Messages : 786
    Par défaut
    J'ai beaucoup utilisé JAD, mais je ne sais pas ce qu'il vaut pour les dernières versions de Java. Je sais pas s'il est compatible Java8 par exemple.

    A tenter !

    http://varaneckas.com/jad/

  6. #6
    Modérateur
    Avatar de ToTo13
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Janvier 2006
    Messages
    5 793
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Santé

    Informations forums :
    Inscription : Janvier 2006
    Messages : 5 793
    Par défaut
    merci, je vais tester.
    Consignes aux jeunes padawans : une image vaut 1000 mots !
    - Dans ton message respecter tu dois : les règles de rédaction et du forum, prévisualiser, relire et corriger TOUTES les FAUTES (frappes, sms, d'aurteaugrafe, mettre les ACCENTS et les BALISES) => ECRIRE clairement et en Français tu DOIS.
    - Le côté obscur je sens dans le MP => Tous tes MPs je détruirai et la réponse tu n'auras si en privé tu veux que je t'enseigne.(Lis donc ceci)
    - ton poste tu dois marquer quand la bonne réponse tu as obtenu.

Discussions similaires

  1. Réponses: 1
    Dernier message: 29/06/2010, 15h50
  2. Connaître les requêtes reçues par Oracle XE
    Par benben02 dans le forum Administration
    Réponses: 1
    Dernier message: 08/12/2008, 08h44
  3. Comment connaître les fichiers visibles par le serveur
    Par Najdar dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 10/04/2008, 13h41
  4. Réponses: 1
    Dernier message: 11/12/2007, 17h34
  5. [Tableaux] Suivre les modifications faits par chaque utilisateur
    Par dessinateurttuyen dans le forum Langage
    Réponses: 7
    Dernier message: 19/07/2006, 10h05

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo