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

Collection et Stream Java Discussion :

[debutant] Récupérer un intervalle de temps


Sujet :

Collection et Stream Java

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    56
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2004
    Messages : 56
    Points : 49
    Points
    49
    Par défaut [debutant] Récupérer un intervalle de temps
    salut

    je voudrais recuperer le temps que fais un traitement
    donc j'utilise ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    long temps = (new GregorianCalendar()).getTimeInMillis();
    traitement ();
    temps = (new GregorianCalendar()).getTimeInMillis() - temps;
    existe-t'il une autre méthode moins couteuse (sans création d'objet par exemple)

  2. #2
    Membre averti
    Inscrit en
    Mars 2004
    Messages
    377
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 377
    Points : 356
    Points
    356
    Par défaut
    Plus simple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    long debut = System.currentTimeInMillis(); 
    traitement (); 
    System.out.println("temps ecoule :"+(System.currentTimeInMillis()-debut));

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    137
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Juillet 2002
    Messages : 137
    Points : 143
    Points
    143
    Par défaut
    Tu as ca :

    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
    // Get current time
        long start = System.currentTimeMillis();
     
        // Do something ...
     
        // Get elapsed time in milliseconds
        long elapsedTimeMillis = System.currentTimeMillis()-start;
     
        // Get elapsed time in seconds
        float elapsedTimeSec = elapsedTimeMillis/1000F;
     
        // Get elapsed time in minutes
        float elapsedTimeMin = elapsedTimeMillis/(60*1000F);
     
        // Get elapsed time in hours
        float elapsedTimeHour = elapsedTimeMillis/(60*60*1000F);
     
        // Get elapsed time in days
        float elapsedTimeDay = elapsedTimeMillis/(24*60*60*1000F);

  4. #4
    Membre éprouvé
    Profil pro
    Architecte technique
    Inscrit en
    Mars 2002
    Messages
    966
    Détails du profil
    Informations personnelles :
    Âge : 51
    Localisation : France

    Informations professionnelles :
    Activité : Architecte technique

    Informations forums :
    Inscription : Mars 2002
    Messages : 966
    Points : 1 085
    Points
    1 085
    Par défaut
    Pourquoi utiliser GreporianCalendar qui est un objet assez compet et donc avide me mémoire, la toute simple classe java.util.Date faisq tout à fait l'affaire:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    long temps = (new Date()).getTime(); 
    traitement (); 
    temps = (new Date()).getTime() - temps;
    Sinon savoir ce qui est plus couteux entre l'appel à une méthode statique de la classe System et la création d'un objet type Date (en supposant que le constructeur de Date effectue sinon le même traitement tout du moins un traitement très proche par rapport à la classe System.currentTime... ) je pense que c'est archi négligeable...

    La différence doit se faire en millième de secondes, ce qui est dans tout les cas très peu couteux...

    Je vois donc pas pourquoi tu dis que le traitement de nex GregorianCalendar est très couteux ???

    Sinon, certes peut-être que tu veux avoir un temps de traitement à la millionième de seconde près... En tout cas, la mesure du temps de traitement est utile pour des traitements plutôt couteux donc une différence de quelques millième de seconde est négligeable...

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    56
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2004
    Messages : 56
    Points : 49
    Points
    49
    Par défaut
    merci a vous deux

    ça marche super donc le pb est RESOLU
    donc encore merci (surtout pour la vitesse)

    !!! le nom exact de la methode est :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    long time =System.currentTimeMillis();
    et non :

    System.currentTimeInMillis()

  6. #6
    Membre averti
    Inscrit en
    Mars 2004
    Messages
    377
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 377
    Points : 356
    Points
    356
    Par défaut
    Désolé j'ai essayé de faire çà de tête !!

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 2
    Dernier message: 05/10/2004, 22h43
  2. [Interbase 6]Stocker l'intervalle de temps
    Par Andry dans le forum InterBase
    Réponses: 4
    Dernier message: 11/08/2004, 07h48
  3. [Timer]Comment mesurer un intervalle de temps ?
    Par Pill_S dans le forum Collection et Stream
    Réponses: 3
    Dernier message: 07/05/2004, 17h39

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