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

Autres Java Discussion :

[AspectJ] La durée d'initialisation d'un object


Sujet :

Autres Java

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2008
    Messages : 28
    Points : 29
    Points
    29
    Par défaut [AspectJ] La durée d'initialisation d'un object
    Salut.
    Je veut calculer le temps d'itialisation d'un object à l'aide de aspectJ.

    J'ai une classe A:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
     
    public class TestA {
     
    	int x;
    	 String y;
    	 public TestA(int a,String b){x=a;y=b;}
     
    	public static void main(String[] args) 
     
    	{		
    		System.out.printf("instantisation    ");
    		TestA A;
    		A=new TestA(5,"Bonjours");
    	}
     
    }
    mon aspect est

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
     
    public aspect Aspect
    {
    	public Date TestA.D;
     
    	pointcut Initialisation():
    		call (TestA.new(..)) 
    		;
     
     
    	Object around(): Initialisation()
    	{
    		System.out.println(" debut initialisation "+ System.currentTimeMillis());		
    		Object O=proceed();
    		System.out.println(" fin initialisation "+ System.currentTimeMillis());	
    		return O;
    	}

    Mon probleme est qu'il maffiche exactement le meme temps avant et aprés l'execution l'intialisation.
    Qui a une idée pourquoi?

    Merci d'avance de votre aide

  2. #2
    Membre éprouvé
    Avatar de LinkinSelim
    Profil pro
    Enseignant Chercheur
    Inscrit en
    Mars 2006
    Messages
    365
    Détails du profil
    Informations personnelles :
    Localisation : Algérie

    Informations professionnelles :
    Activité : Enseignant Chercheur

    Informations forums :
    Inscription : Mars 2006
    Messages : 365
    Points : 1 034
    Points
    1 034
    Par défaut
    Tout simplement parce que les opération de ton constructeur ne prennent pas 0 millisecondes de temps pour s'exécuter. J'ai ajouter dans ton code une boucle qui calcule 6 millions de fois le sinus d'un nombre. Essai le et tu va voir que ca va changer.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
     
    public class TestA {
     
    	int x;
    	 String y;
    	 public TestA(int a,String b){
    		 x=a;y=b;
    		 double j;
    		 for (int i=0;i<6000000;i++)
    			 j = Math.sin(i);
     
    	 }
     
    	public static void main(String[] args) 
     
    	{		
    		System.out.printf("instantisation    ");
    		TestA A;
    		A=new TestA(5,"Bonjours");
    	}
     
    }

  3. #3
    Expert éminent sénior
    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
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Salut,

    Citation Envoyé par LinkinSelim Voir le message
    Tout simplement parce que les opération de ton constructeur ne prennent pas 0 millisecondes de temps pour s'exécuter.
    Pas forcément...

    En fait malgré le fait qu'elle renvoie un temps en millisecondes, la méthode System.currentTimeMillis() n'a pas forcément une telle précision. Cela dépend en réalité de la machine et de l'OS hôte, mais cela tourne généralement autour de 16ms...

    Pour des mesures plus précises, il faudra se tourner vers System.nanoTime() ou effectuer un calcul moyen sur un très grand nombre d'appel...

    a++

  4. #4
    Membre éprouvé
    Avatar de LinkinSelim
    Profil pro
    Enseignant Chercheur
    Inscrit en
    Mars 2006
    Messages
    365
    Détails du profil
    Informations personnelles :
    Localisation : Algérie

    Informations professionnelles :
    Activité : Enseignant Chercheur

    Informations forums :
    Inscription : Mars 2006
    Messages : 365
    Points : 1 034
    Points
    1 034
    Par défaut
    En effet, AdiGuba a tout à fait raison pour ce qui est de la méthode System.currentTimeMillis().

    En effet, si tu utilise System.nanoTime(), t'aura un résultat extrêmement précis.

  5. #5
    Expert éminent sénior
    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
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par LinkinSelim Voir le message
    En effet, si tu utilise System.nanoTime(), t'aura un résultat extrêmement précis.
    Attention car si nanoTime() est plus précis que currentTimeMillis(), il possède le même "problème".

    C'est à dire qu'il n'y a aucune garantie d'avoir une précision à la nanosecondes près car cela dépend encore une fois de l'hôte...


    a++

  6. #6
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2008
    Messages : 28
    Points : 29
    Points
    29
    Par défaut
    Avec System.nanoTime() ca marche enfin.
    J'ai ajouter une ligne qui me calcule la durée.
    Mais le problème que pour la même instruction d'initialisation il me sorte une résultat.
    C'est bizarre comme même...Mais comme adiGuba a dit...la précision manque a ses fonctions.

    Merci

  7. #7
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    d'un appel à l'autre le temps peut etre différent à cause de facteur multiples: charge de l'os, autre application utilisant le cpu à ce moment là, nécessiter de faire tourner le garbage collector pour allouer de lamémoire, nécessité d'allouer de la mémoire système, etc.

Discussions similaires

  1. Réponses: 3
    Dernier message: 08/04/2013, 08h26
  2. Initialiser une durée
    Par Palsajicoco dans le forum Débuter avec Java
    Réponses: 18
    Dernier message: 30/05/2011, 14h55
  3. Initialiser Object Select
    Par gdev7 dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 03/06/2009, 09h15
  4. Initialisation object intance/null
    Par maxf1 dans le forum Hibernate
    Réponses: 2
    Dernier message: 07/08/2007, 17h20
  5. Initialisation d'une variable Object
    Par bobic dans le forum Langage
    Réponses: 2
    Dernier message: 08/09/2006, 17h21

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