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 :

[JVMTI] Comment identifier une méthode/fonction ?


Sujet :

Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Avril 2010
    Messages
    18
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2010
    Messages : 18
    Par défaut [JVMTI] Comment identifier une méthode/fonction ?
    Bonjour,
    je suis en train de développer un agent JVMTI pour calculer le temps d'exécution des fonctions/méthodes appelées dans une application Java. Pour cela, j'ai défini les fonctions associées aux évènements d'entrée et de sortie de méthode (callbacks.MethodEntry = &cb_method_entry; callbacks.MethodExit = &cb_method_exit.
    Dans la fonctions gérant l'évènement MethodEntry, je stocke l'heure courante, et dans celle de MethodExit je fais une bête soustraction pour obtenir le temps d'exécution. Pour ne pas mélanger les différents temps des différentes fonctions java qui peuvent être appelées, j'ai d'abord pensé à les stocker dans une map avec pour identifiant leur nom.
    Là où ca se complique c'est si la même fonction est appelée 2 fois, éventuellement même 2 fois par différents threads par exemple.
    Je ne peux donc pas utiliser le nom comme identifiant...
    Y a-t-il un autre moyen d'identifier une fonction, autrement que par son nom (un ID de fonction?), de sorte qu'à chaque exécution l'identifiant soit différent?
    J'espère ne pas avoir été trop confus

  2. #2
    Modérateur

    Homme Profil pro
    Développeur java, access, sql server
    Inscrit en
    Octobre 2005
    Messages
    2 713
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur java, access, sql server
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2005
    Messages : 2 713
    Par défaut
    Pourquoi ne pas créer une petite classe ayant pour champs :
    - nom de fonction
    - durée
    - ... éventuellement d'autres informations ...

    à chaque utilisation d'une fonction, tu crées un objet de cette classe
    et tu stockes dans une liste que tu peux exploiter en statistiques
    Labor improbus omnia vincit un travail acharné vient à bout de tout - Ambroise Paré (1510-1590)

    Consulter sans modération la FAQ ainsi que les bons ouvrages : http://jmdoudoux.developpez.com/cours/developpons/java/

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Avril 2010
    Messages
    18
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2010
    Messages : 18
    Par défaut
    justement, c'est ce que j'ai fait pour l'instant, mais cela pose problème dans le cas où la même fonction pourrais être appelée une première fois, puis une seconde fois avant même que la première exécution ne soit terminée (par exemple dans le cas d'un programme multithread ou plus simplement une fonction récursive).
    Il y aura donc 2 entités de la classe avec le même nom de fonction, ce qui pose problème : comment savoir laquelle vient de se terminer?

  4. #4
    Expert confirmé
    Avatar de sinok
    Profil pro
    Inscrit en
    Août 2004
    Messages
    8 765
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Août 2004
    Messages : 8 765
    Par défaut
    Suffit de stocker ça sous le nom du Thread appelant.

    Sinon la méthode hashCode de la classe (si correctement codée bien sur) pourrait faire l'affaire...

  5. #5
    Membre éclairé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2007
    Messages
    697
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Janvier 2007
    Messages : 697
    Par défaut
    Quelques idées :

    • Si tes fonctions sont exécutées dans des Threads différents, tu peux utiliser comme clé dans ta map la concaténation du nom de ta fonction et de l'id du thread. Tu peux récupérer ce dernier ainsi :
      Code : Sélectionner tout - Visualiser dans une fenêtre à part
      long tid = Thread.currentThread().getId();


    • Si tes fonctions sont récursives, ça va être un peux plus dure mais tu peux peut-être essayer d'ajouter en plus à ta clé le nombre de méthode invoqué :
      Code : Sélectionner tout - Visualiser dans une fenêtre à part
      int countMethodInvocation = Thread.currentThread().getStackTrace().length -1;
      Les élément du tableau sont supprimés (à vérifier, j'ai pas testé) à la sortie de la fonction donc tu dois pouvoir t'en sortir.


    • Au pire tes appels récursif de fonction sont gérable en utilisant une pile ou un simple indice spécifique au Thread

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Avril 2010
    Messages
    18
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2010
    Messages : 18
    Par défaut
    Effectivement, ca me parait être une bonne solution. Je vais faire ca, merci beaucoup!

Discussions similaires

  1. Réponses: 4
    Dernier message: 28/03/2008, 21h43
  2. Comment identifier une machine de facon unique ?
    Par BigBenQ dans le forum Développement
    Réponses: 14
    Dernier message: 19/12/2005, 08h36
  3. Réponses: 2
    Dernier message: 31/08/2005, 16h12
  4. comment identifier une transaction http?
    Par didier.cabale dans le forum Développement
    Réponses: 5
    Dernier message: 13/04/2005, 16h42

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