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 :

Itération/recherche, meilleure façon de faire?


Sujet :

Langage Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    36
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 36
    Par défaut Itération/recherche, meilleure façon de faire?
    Bonsoir tout le monde,

    Il y'a une question qui me trotte dans la tête depuis un moment. Voilà je fais par habitude mes recherches ou autres itérations de la façon suivante :

    1:

    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
     
    public PosteBudgétaire getPoste(String s){
    		boolean trouvé=false;
    		PosteBudgétaire posteBudgétaireARetourner=null;
    		PosteBudgétaire posteBudgétaire;
    		Iterator ite = postes.iterator();
    		while(ite.hasNext() && !trouvé){
    			posteBudgétaire = (PosteBudgétaire) ite.next();
    			if( posteBudgétaire.getLabel().compareToIgnoreCase(s)==0 ){
    				trouvé=true;
    				posteBudgétaireARetourner=posteBudgétaire;
    			}
    		}
    		return posteBudgétaireARetourner;
    	}
    Il me semblait qu'un professeur m'avait recommandé de ne jamais mettre plusieurs return. Pourtant en réfléchissant le mettre de mettre un return avt permet de sortir de la boucle plus tôt si l'objet est trouvé. Et en plus sur les exemples de codes rencontrés sur le net c'est souvent l'autre façon

    ce qui donnerait

    2:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    	public PosteBudgétaire getPoste(String s){
    		PosteBudgétaire posteBudgétaire;
    		Iterator ite = postes.iterator();
    		while(ite.hasNext()){
    			posteBudgétaire = (PosteBudgétaire) ite.next();
    			if( posteBudgétaire.getLabel().compareToIgnoreCase(s)==0 ){
    				return posteBudgétaire;
    			}
    		}
    		return posteBudgétaire;
    	}
    Quelle méthode est donc meilleure syntaxiquement? la 1 ou la 2?

    merci d'avance =)

  2. #2
    Membre éclairé
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    47
    Détails du profil
    Informations personnelles :
    Localisation : France, Savoie (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2008
    Messages : 47
    Par défaut
    Pour ma part, je préfère la première car je n'aime pas non plus mettre plusieurs return dans une fonction.

  3. #3
    Membre éprouvé
    Avatar de mavina
    Homme Profil pro
    Développeur Java
    Inscrit en
    Octobre 2004
    Messages
    1 812
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Chine

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2004
    Messages : 1 812
    Par défaut
    Coucou,

    la deuxième sans hésitation.

    Le return te permet d'éviter de continuer l'itération pour rien. Tu as trouvé, tu retournes. C'est comme ci tu cherchais apres quelque chose, que tu le trouvais dans une étagere mais que tu continuais à chercher dans les autres...

    F.

  4. #4
    Membre émérite
    Profil pro
    Inscrit en
    Février 2007
    Messages
    572
    Détails du profil
    Informations personnelles :
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Février 2007
    Messages : 572
    Par défaut
    Par contre, ca s'ecrit plutot comme ca :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    public PosteBudgétaire getPoste(String s){
      Iterator ite = postes.iterator();
      while(ite.hasNext()){
        PosteBudgétaire posteBudgétaire = (PosteBudgétaire) ite.next();
        if( posteBudgétaire.getLabel().compareToIgnoreCase(s)==0 ){
    	return posteBudgétaire;
        }
      }
      return null;
    }
    Mais c'est surtout une histoire de gout.

  5. #5
    Membre chevronné Avatar de T`lash
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2007
    Messages
    381
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Saint-Pierre-Et-Miq.

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Biens de consommation

    Informations forums :
    Inscription : Septembre 2007
    Messages : 381
    Par défaut
    Moi aussi je préfère la solution des return, mais il en existe une autre ; plutôt que ta variable trouvé tu peux utiliser un break.

  6. #6
    Membre extrêmement actif
    Profil pro
    Développeur Java Indépendant
    Inscrit en
    Mai 2007
    Messages
    1 333
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur Java Indépendant

    Informations forums :
    Inscription : Mai 2007
    Messages : 1 333
    Par défaut
    Je crois que les breaks sont aussi très déconseillés...

    Je pense que la meilleur façon est de faire comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    public PosteBudgétaire getPoste(String s){
    		PosteBudgétaire posteBudgétaire;
                    PosteBudgétaire posteBudgétaireARetourner = null;
    		Iterator ite = postes.iterator();
                    boolean trouve = false;
    		while(ite.hasNext() && trouve == false){
    			posteBudgétaire = (PosteBudgétaire) ite.next();
    			if( posteBudgétaire.getLabel().compareToIgnoreCase(s)==0 ){
                                    posteBudgétaireARetourner = posteBudgétaire;
                                    trouve = true;
    			}
    		}
    		return posteBudgétaireARetourner ;
    	}
    De cette manière, on ne continue pas à chercher alors qu'on a pas trouvé, et on n'utilise pas plusieurs return....
    Mais dans la pratique, je mettrais plusieurs return, puisque la fonction est petite et donc facilement compréhensible.

  7. #7
    Membre expérimenté
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    282
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 282
    Par défaut
    Citation Envoyé par Sanguko Voir le message
    Par contre, ca s'ecrit plutot comme ca :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    public PosteBudgétaire getPoste(String s){
      Iterator ite = postes.iterator();
      while(ite.hasNext()){
        PosteBudgétaire posteBudgétaire = (PosteBudgétaire) ite.next();
        if( posteBudgétaire.getLabel().compareToIgnoreCase(s)==0 ){
    	return posteBudgétaire;
        }
      }
      return null;
    }
    Mais c'est surtout une histoire de gout.
    Je prendrais cette solution aussi :p même si j'ai toujours cette grosse voix d'un prof d'IUT dans la tête qui me dit : "Une fonction, un return !" méthode monsieur, une méthode

  8. #8
    Membre chevronné Avatar de themadmax
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    446
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 446
    Par défaut
    Ah, je suis content de tomber sur ce poste!
    Voila moi je suis un adepte du return, et j'ai aussi entendu du mal de lui!
    Parcontre on ne ma jamais dit aucun argument!

    Donc j'exprime les miens pour le return :
    • Quand on trouve l'item, on sort directement on sait que rien d'autre ne sera fait pas la suite (parfois loin dans la fonction). On retourne directement l'objet trouvé, qui parfois n'est plus valable en dehors de la boucle.
    • Simplicité de code : rajouter un boolean dans un for ou un while je trouve cela pas très visible, et biensur qui dit rajout de code dit rajout potentiel de bug!
    • Lors de 15 conditions dans une fonction on se retrouve avec un bon nombre d'indentation si on ne fait pas des return à chaque condition.
    • En C le code generé est plus long (rajout d'une condition) ce qui pour des grande recherche peut s'averer un peu plus couteux.

Discussions similaires

  1. La meilleur façon de faire une recherche ?
    Par Jcpan dans le forum PL/SQL
    Réponses: 21
    Dernier message: 06/10/2008, 11h25
  2. Réponses: 16
    Dernier message: 18/08/2008, 19h29
  3. Réponses: 8
    Dernier message: 18/01/2008, 16h58
  4. Réponses: 1
    Dernier message: 08/08/2007, 09h45
  5. Est ce bien la meilleure façon de faire un histogramme ?
    Par rvzip64 dans le forum Algorithmes et structures de données
    Réponses: 2
    Dernier message: 10/05/2005, 13h41

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