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 :

[String] Probleme d'index


Sujet :

Langage Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de menuge
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    727
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Avril 2004
    Messages : 727
    Par défaut [String] Probleme d'index
    salut à tous, voici mon code:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    if(fromFile){tempOffSet = this.text.indexOf(" " + (String)words.get(i) + " ",tempOffSet+1);}else{
    tempOffSet = this.text.indexOf((String)words.get(i),tempOffSet+1);
    }
    Quand je suis dans le else, tout se passe bien, mais dans l'autre cas (j'ajoute 2 espaces), c'est super long!

    Quelqu'un voit une (grosse) connerie de ma part?

    MErci d'avance

  2. #2
    Rédacteur
    Avatar de bulbo
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Février 2004
    Messages
    1 259
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Finance

    Informations forums :
    Inscription : Février 2004
    Messages : 1 259
    Par défaut
    Pas une grosse connerie mais ...

    1- aere ton code c'est plus maintenable et lisible

    2- evite les concatenation de chaines avec "+" mais utilise plutot un StringBuffer

    Essaye voir comme ca pour voir si tu gagnes en perfs:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    if (fromFile)
    {
      StringBuffer buf = new StringBuffer(" ").append((String) words.get(i)).append(" ");
      tempOffSet = this.text.indexOf(buf.toString(),tempOffSet+1);
    }
    else
    {
      tempOffSet = this.text.indexOf((String)words.get(i),tempOffSet+1);
    }
    Sinon c'est peut-etre tout simplement parce qu'il ne trouve pas la sous-chaine avec les 2 espaces en plus et que du coup il est oblige de chercher sur toute la chaine au lieu de s'arreter des qu'il trouve.

    Bulbo
    [Java] [NetBeans] [CVS]
    La FAQ Java
    Merci de ne pas me poser de questions techniques par MP.

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

    Citation Envoyé par bulbo
    1- aere ton code c'est plus maintenable et lisible
    +1 : un code lisible c'est nettement mieux

    Citation Envoyé par bulbo
    2- evite les concatenation de chaines avec "+" mais utilise plutot un StringBuffer
    Dans ce cas là le StringBuffer est "inutile" puisque c'est exactement ce que fait l'opérateur + :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    tempOffSet = this.text.indexOf(" " + (String)words.get(i) + " ",tempOffSet+1);
    Est l'équivalent de :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    tempOffSet = this.text.indexOf(new StringBuffer(" ").append((String)words.get(i)).append(" ").toString(),tempOffSet+1);
    Donc l'opérateur + ne gène pas (au contraire il facilite la lisibilité).

    C'est dans une boucle qu'il faut éviter de l'utiliser afin d'éviter de créer un StringBuffer temporaire à chaque itération...



    Sinon pour ton problème, il nous faudrait un jeu de donnée pour tester, ainsi que la valeur de words.get(i)...

    a++

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

    Informations professionnelles :
    Activité : Architecte technique

    Informations forums :
    Inscription : Mars 2002
    Messages : 966
    Par défaut
    Citation Envoyé par adiGuba
    C'est dans une boucle qu'il faut éviter de l'utiliser afin d'éviter de créer un StringBuffer temporaire à chaque itération...
    +1

    Tout à fait d'accord, il ne faut pas être plus royaliste que le roi..

  5. #5
    Membre expérimenté

    Profil pro
    Chercheur en informatique
    Inscrit en
    Novembre 2004
    Messages
    130
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chercheur en informatique

    Informations forums :
    Inscription : Novembre 2004
    Messages : 130
    Par défaut
    Salut,

    Indente ton code, ce sera un peu plus clair...
    Sinon je ne pense pas que le fait de rajouter 2 espaces augmente considérablement le temps de traitement (Même si je pense qu'il vaut mieux utiliser un StringBuffer).
    Par contre regarde si tes variables on les mêmes valeurs quand tu es dans le if et dans le else.

    Grilled

  6. #6
    Membre éclairé Avatar de menuge
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    727
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Avril 2004
    Messages : 727
    Par défaut
    Désolé pour l'aération du code, mais j'ai fait un copier-coller de mon emacs et je comprends pas pourquoi il n'a pas gardé l'indentation.

    Sinon, je vais essayer le StringBuffer...Merci

  7. #7
    Membre éclairé Avatar de menuge
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    727
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Avril 2004
    Messages : 727
    Par défaut
    Ca ne marche pas...

    Je ne comprends pas du tout ce qui peut se passer...

  8. #8
    Membre Expert
    Avatar de ®om
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    2 815
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2 815
    Par défaut
    Combien de caractères comporte ta chaîne?

  9. #9
    Membre éclairé Avatar de menuge
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    727
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Avril 2004
    Messages : 727
    Par défaut
    pas plus de 10 en gros.

    En fait, je récupère un texte et je dois retourner toutes les occurences (index) d'un mot. Et afin de m'assurer que c'est bien le mot, je fais:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    text = text.replaceAll("[^a-zA-Z]", " ");
    Et ensuite, je cherche le mot entouré de 2 espaces. Comme cela, ca m'évite d'avoir l'index de images alors que je cherche image

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

Discussions similaires

  1. [String] Problème de limitation de caractères
    Par zegreg dans le forum Langage
    Réponses: 11
    Dernier message: 18/01/2006, 16h25
  2. Probleme d'index fulltext assez bizarre
    Par Clovis37 dans le forum Débuter
    Réponses: 4
    Dernier message: 08/07/2005, 19h59
  3. [IMP/EXP] Probleme d'index unique
    Par rours dans le forum Oracle
    Réponses: 17
    Dernier message: 18/05/2005, 15h37
  4. [String] Probleme incomprehensible avec split
    Par scorpiwolf dans le forum Collection et Stream
    Réponses: 3
    Dernier message: 20/07/2004, 21h21

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