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 :

Iterator Vs Boucle


Sujet :

Langage Java

  1. #1
    Membre confirmé

    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Août 2007
    Messages
    509
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Août 2007
    Messages : 509
    Points : 622
    Points
    622
    Par défaut Iterator Vs Boucle
    Bonjour,
    Entre un iterator et une boucle (boucle for, while, do/while) en java, lequel est
    le plus rapide?

  2. #2
    Expert éminent sénior Avatar de Uther
    Homme Profil pro
    Tourneur Fraiseur
    Inscrit en
    Avril 2002
    Messages
    4 562
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Tourneur Fraiseur

    Informations forums :
    Inscription : Avril 2002
    Messages : 4 562
    Points : 15 493
    Points
    15 493
    Par défaut
    Pour un ArrayList, les performances seront très légèrement meilleures avec un for, mais ca reste vraiment marginal.
    Par contre si tu as une liste chainée, les performances vont devenir catastrophique si tu utilises le for directement au lieu d'un itérateur.

    Je manière générale mieux vaut utiliser foreach ou l'itérateur, a moins d'être sur de ce que tu fais.

  3. #3
    Membre confirmé

    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Août 2007
    Messages
    509
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Août 2007
    Messages : 509
    Points : 622
    Points
    622
    Par défaut
    Salut et merci pour ta réponse,

    est ce qu'il est possible par exemple dans une ArrayList de changer dynamiquement un élément de cette liste.
    Je pense à un truc comme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    for (MyObject o : ArrayList<MyObject>){
        if (o.getName().equals("un nom passé en param")){
            o.setVisibility (false);
       }
    }

  4. #4
    Expert éminent sénior Avatar de Uther
    Homme Profil pro
    Tourneur Fraiseur
    Inscrit en
    Avril 2002
    Messages
    4 562
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Tourneur Fraiseur

    Informations forums :
    Inscription : Avril 2002
    Messages : 4 562
    Points : 15 493
    Points
    15 493
    Par défaut
    Bien sur.

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    338
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2008
    Messages : 338
    Points : 402
    Points
    402
    Par défaut
    Comme l'a spécifié Uther pour une liste RandomAccess (ArrayList par exemple), la boucle for la plus rapide est de la forme
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    for(int i = 0, size = list.size(); i < size; i++) {
     MyObject o = (MyObject) list.get(i);
     //...etc
    }
    Sinon faut utiliser Iterator pour une Collection don't tu ne sais pas vraiment son type réel.

  6. #6
    Membre confirmé

    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Août 2007
    Messages
    509
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Août 2007
    Messages : 509
    Points : 622
    Points
    622
    Par défaut
    Bah ok merci pour l'info

  7. #7
    Modérateur

    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    12 551
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 12 551
    Points : 21 607
    Points
    21 607
    Par défaut
    Citation Envoyé par hibour Voir le message
    Comme l'a spécifié Uther pour une liste RandomAccess (ArrayList par exemple), la boucle for la plus rapide est de la forme
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    for(int i = 0, size = list.size(); i < size; i++) {
     MyObject o = (MyObject) list.get(i);
     //...etc
    }
    Oui c'est vrai, mais la différence est négligeable. À mon avis il vaut mieux se concentrer sur la lisibilité du code et aussi se passer d'un index i dont on n'a pas besoin.

    Citation Envoyé par hibour Voir le message
    Sinon faut utiliser Iterator pour une Collection don't tu ne sais pas vraiment son type réel.
    Une boucle foreach, je dirais. Et dans tous les cas, puisque ça n'a pas d'importance.
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  8. #8
    Membre averti
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    338
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2008
    Messages : 338
    Points : 402
    Points
    402
    Par défaut
    Citation Envoyé par thelvin Voir le message
    Une boucle foreach, je dirais. Et dans tous les cas, puisque ça n'a pas d'importance.
    Seulement si on utilise une version java >= 1.5
    A++

  9. #9
    Expert éminent sénior Avatar de Uther
    Homme Profil pro
    Tourneur Fraiseur
    Inscrit en
    Avril 2002
    Messages
    4 562
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Tourneur Fraiseur

    Informations forums :
    Inscription : Avril 2002
    Messages : 4 562
    Points : 15 493
    Points
    15 493
    Par défaut
    A noter que le foreach reviens exactement à la même chose qu'utiliser un Iterateur.

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

Discussions similaires

  1. Passer directement a l'iteration suivante dans une boucle for
    Par sundjata dans le forum VB 6 et antérieur
    Réponses: 7
    Dernier message: 26/07/2023, 12h40
  2. [Débutant] stockage d'iterations de boucle for
    Par jenaCa dans le forum MATLAB
    Réponses: 1
    Dernier message: 16/04/2015, 07h30
  3. parcourt d'un vector avec iterator et boucle for
    Par Benoit_T dans le forum Débuter
    Réponses: 8
    Dernier message: 27/03/2009, 18h42
  4. Réponses: 1
    Dernier message: 22/04/2007, 16h51
  5. [logic:iterate] arreter la boucle
    Par D.Mounir dans le forum Struts 1
    Réponses: 33
    Dernier message: 06/03/2007, 15h18

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