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

Langage Java Discussion :

[Language]Calculer Vitesse d'execution


Sujet :

Langage Java

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 42
    Points : 23
    Points
    23
    Par défaut [Language]Calculer Vitesse d'execution
    Bonjour,

    je dispose d'une chaine de caractére (en fait plusieurs milliers) que je dois comparer à une auter chaine.
    Cette chaine est de la forme "1352".

    Qu'elle est la manière la plus rapide de réaliser cette comparaison :
    - transformer la chaine en int puis réaliser les comparaisons == et >
    - de comparer les chaines entre elles avec compareTo et equals

    Merci pour vos commentaires,
    Jean-Marie

  2. #2
    Membre régulier Avatar de jiraiya
    Inscrit en
    Mai 2002
    Messages
    100
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 100
    Points : 116
    Points
    116
    Par défaut
    solution 2 car tu feras bcp moins de calculs par rapport à la transformation en int

  3. #3
    Membre confirmé Avatar de Mobius
    Profil pro
    none
    Inscrit en
    Avril 2005
    Messages
    463
    Détails du profil
    Informations personnelles :
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : none

    Informations forums :
    Inscription : Avril 2005
    Messages : 463
    Points : 558
    Points
    558
    Par défaut
    je vote aussi pour la version 2 pour a peu pres les meme raison
    Librairie d'accès LDAP en Java : LdapBeans
    et pensez au tag

  4. #4
    Membre confirmé
    Avatar de Glob
    Homme Profil pro
    Architecte de système d'information
    Inscrit en
    Avril 2002
    Messages
    428
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Suisse

    Informations professionnelles :
    Activité : Architecte de système d'information

    Informations forums :
    Inscription : Avril 2002
    Messages : 428
    Points : 630
    Points
    630
    Par défaut
    Hello.
    Moi je vote pour réaliser les deux façons de faire et de comparer les perfs. En cas de temps d'exécution trop petit, faire répéter l'opération 1000 ou 10000 fois.

    Et effectuer les mesures à coup de System.currentTimeMillis()...

    A+
    Glob
    What would you do if you were not afraid?

    Cours et tutoriels pour apprendre Java , FAQ Java, et Forum Java

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    119
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2003
    Messages : 119
    Points : 100
    Points
    100
    Par défaut
    salut,
    tu peux comparer :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    long d=System.currentTimeMillis();
    // ton operation avec "comparaisons == et >"
    long f=System.currentTimeMillis();
    // f-d te donne une estimation du temps utilisé par ton operation
    puis recoder avec en operation "compareTo et equals"

  6. #6
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 42
    Points : 23
    Points
    23
    Par défaut
    Merci pour vos commentaires.

    Je vous tiendrai informé des résultats de mes testes (pour la fin de la semaine je pense).

  7. #7
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 42
    Points : 23
    Points
    23
    Par défaut
    Bon, ce n'est pas le pied : je ne dois pas tout avoir compris au fonctionnement de la fonction "compareTo" :
    me donne une valeur positive (7) :

    Il va faloir que je reconsidére mon idée de trier les string de cette façon.

    Bonne soirée,
    Jean-Marie

  8. #8
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    429
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 429
    Points : 475
    Points
    475
    Par défaut
    Ce résultat ne semble pas surprenant vu la doc. de SUN :

    compareTo
    public int compareTo(String anotherString)
    Compares two strings lexicographically. The comparison is based on the Unicode value of each character in the strings. The character sequence represented by this String object is compared lexicographically to the character sequence represented by the argument string. The result is a negative integer if this String object lexicographically precedes the argument string. The result is a positive integer if this String object lexicographically follows the argument string. The result is zero if the strings are equal; compareTo returns 0 exactly when the equals(Object) method would return true.
    Nicolas

  9. #9
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 42
    Points : 23
    Points
    23
    Par défaut
    Oui je suis tout à fait d'accord avec toi, mais il me semblait que cet ordre devait justement donner "190" plus grand que "128".

    Si tu pouvais me donner quelques explications supplémentaires .

    Jean-Marie

  10. #10
    Membre confirmé Avatar de Mobius
    Profil pro
    none
    Inscrit en
    Avril 2005
    Messages
    463
    Détails du profil
    Informations personnelles :
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : none

    Informations forums :
    Inscription : Avril 2005
    Messages : 463
    Points : 558
    Points
    558
    Par défaut
    The result is a positive integer if this String object lexicographically follows the argument string
    190>128 ==> nombre positif (7 est bien un nombre positif)
    donc rien de surprenant
    on aurait du s'inquiter si t'auvais eut un nb negatif !!
    Librairie d'accès LDAP en Java : LdapBeans
    et pensez au tag

  11. #11
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 42
    Points : 23
    Points
    23
    Par défaut
    Merci pour tes commentaires. Je crois avoir compris d'où vient mon probléme.
    En fait avant cette valeur de 128, j'ai passé dans cette expression des string égales à "48", "65", qui elles ont été trouvées plus grandes que mon "190".

    Donc si je ne me trompe pas cette fois le classement doit être pour ces objet string : 128, 190, 48, 65.

    Si je rajoute un 0 devant 48 et 65 je devrais donc avoir : 048, 065, 128, 190

    Ce raisonnement est-il correcte ?

  12. #12
    Membre confirmé Avatar de Mobius
    Profil pro
    none
    Inscrit en
    Avril 2005
    Messages
    463
    Détails du profil
    Informations personnelles :
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : none

    Informations forums :
    Inscription : Avril 2005
    Messages : 463
    Points : 558
    Points
    558
    Par défaut
    c'est pas bete du tout
    c'est vrai que 190 se trouve avant 43 dans l'ordre lexicographique alors que tu voudrait le contraire. Rajouter des "0" resoud effectivement le pb.
    plutot que de rajouter des "0", ne serait il pas possibme d'utiliser un nouveau Comparator qui commence par comparé la longueur des chaines ?

    PS: encore attention si tu as par exemple "007" et "56" ? Pour résumé tu aura toujours des pb si tes chaines ne sont pas de longueur egal !
    Librairie d'accès LDAP en Java : LdapBeans
    et pensez au tag

  13. #13
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 42
    Points : 23
    Points
    23
    Par défaut
    C'est fait cela fonctionne et c'est assez rapide, par contre je n'ai pas encore réalisé l'essai avec la transformation de string vers int.

    Merci pour votre aide,
    Jean-Marie

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

Discussions similaires

  1. macro pour calculer la vitesse d'execution d'une macro
    Par victorzecat dans le forum Macros et VBA Excel
    Réponses: 10
    Dernier message: 08/12/2007, 14h34
  2. vitesse d'execution de calcul
    Par AlfredKr dans le forum C#
    Réponses: 2
    Dernier message: 22/10/2007, 11h42
  3. Réponses: 3
    Dernier message: 16/10/2005, 13h43
  4. Réponses: 1
    Dernier message: 19/03/2005, 22h47
  5. vitesse d'execution
    Par bakonu dans le forum OpenGL
    Réponses: 15
    Dernier message: 07/05/2004, 11h18

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