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 :

a pb sans solution


Sujet :

Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Septembre 2005
    Messages
    30
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 30
    Par défaut a pb sans solution
    bonjour,
    j'ai un pb trés simple mais me donne des résultats illogique , j'ai besoin une personne qui me dit pourquoi le tempsm dans ce code me donne des résulats nulls et des fois négatifs:
    le code est le suivants:
    try {int nbr=5;
    do{
    t1=System.currentTimeMillis();//System.out.println("t1:"+t1);
    for ( int i=0; i<nbr;i++)
    sleep(3000);

    t2=System.currentTimeMillis();System.out.println("t2:"+t2);

    temps=t2-t1-3000*nbr;
    tempsm=temps/nbr;

    System.out.println("load="+tempsm);

    }while ( true);}catch(InterruptedException e) {};
    j'attends votre réponses.
    @+

  2. #2
    Membre expérimenté Avatar de dazz_x
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    269
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations forums :
    Inscription : Mars 2006
    Messages : 269
    Par défaut
    et bien des résultats nuls (ou très proche de 0) je trouverais ça plutôt normal parce que t2-t1 est égal au temps d'execution de nbr boucles de 3000ms d'attente et si par résultats "négatifs" tu entends des résultats du genre : -1.1236548943416436e-15, et bien bienvenue dans le monde du calcul flottant, parce qu'effectivement si les résultats sont trop proches de 0, il peut y avoir ce genre de comportement. Mais bon, 10e-15, c'est quand même très proche de 0.

    Si tout ce que je dis est complètement à côté de la plaque, merci de bien vouloir envoyer les lettres d'insultes sous pli discret.

    Salutations

  3. #3
    Membre expérimenté Avatar de hydraland
    Profil pro
    Développeur Java
    Inscrit en
    Mai 2006
    Messages
    179
    Détails du profil
    Informations personnelles :
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Mai 2006
    Messages : 179
    Par défaut
    Salut,

    Je rajouterai que
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    System.currentTimeMillis()
    est une méthode dépendante de la plate-forme et donc elle n'est pas forcément précise à la milliseconde près. Sous certain OSla précision peut être de l'ordre de la dizaine de millisecondes(C'est écrit dans la javadoc). D'ou les résultats que tu rencontres.

    A+

  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
    Avec ta multiplication, ne se pourrait il pas que tu explose la limite des long (ou int) car au delà d'une certaines valeur tu passe en négatif...

  5. #5
    Membre averti
    Inscrit en
    Septembre 2005
    Messages
    30
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 30
    Par défaut
    dazz_xx: ce code calcule le moyen de temps d'attente d'un thread dans la file d'attente des processus pret dans la JVM,alors ce thread fait un sommeil puis revient à la file d'attente et attend un temp pour faire un autre sommeil, le moyen de ce temps c'est le temps d'attente que je cherchea cet effet t2.t1<> nbr*(temps de sommeil).
    t1 et t2 sont de type long .

    hydraland : je travaille sous windows et System.currentTimeMillis() en miliseconde.
    sinok : n ya pas d'explmosion car lorsque j'affiche 3000*nbr il me donne des bons résultats mais parfois sont supèrieur à t2-t1.
    et merci pour enrichir cette discussion.

  6. #6
    Membre expérimenté Avatar de hydraland
    Profil pro
    Développeur Java
    Inscrit en
    Mai 2006
    Messages
    179
    Détails du profil
    Informations personnelles :
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Mai 2006
    Messages : 179
    Par défaut
    Elalia,

    Dans ton code t2 - t1 = nbr*3000 + temps mise à jour du for.
    Donc la valeur de temps est toujours proche de zéro, puisque le temps de mise à jour du for est négligeable.
    Comme je t'ai indiqué la méthode System.currentTimeMillis() n'a pas forcément une précision de l'ordre
    de la milliseconde (même sous windows) ce qui veut dire que si on considère que ta boucle for prend T millisecondes alors
    t2-t1 = T +/- (2*précision de la méthode System.currentTimeMillis()).

    Sinon peux tu être plus clair sur ton besoin (en bon français s'il te plait ), car je n'ai pas compris ce que tu voulais faire.

    A+

  7. #7
    Membre éclairé
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    57
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 57
    Par défaut
    j'ai un message ici je ne sait pas pourquoi !

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

Discussions similaires

  1. Cas d'etudes avec ou sans solution
    Par casawi dans le forum Débuter
    Réponses: 1
    Dernier message: 12/04/2009, 12h40
  2. WARNING sans solution
    Par jena dans le forum MATLAB
    Réponses: 1
    Dernier message: 05/11/2008, 14h48
  3. 16 erreurs sans solutions
    Par neon29 dans le forum Windows Forms
    Réponses: 7
    Dernier message: 26/09/2008, 19h08
  4. Réponses: 2
    Dernier message: 22/06/2008, 10h05
  5. Ecriture Fat32 : pistes sans solution :-(
    Par tynmar dans le forum Administration système
    Réponses: 9
    Dernier message: 02/05/2006, 15h50

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