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

Collection et Stream Java Discussion :

Trier un arrayList selon differents criteres


Sujet :

Collection et Stream Java

  1. #1
    Membre régulier
    Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    145
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Septembre 2005
    Messages : 145
    Points : 77
    Points
    77
    Par défaut Trier un arrayList selon differents criteres
    Bonjour,

    j'ai une classe qui contient un arrayList qui est composé d'objet disons voiture et je souhaite le trier.

    je me suis baser sur l'aide dans la FAQ
    http://java.developpez.com/faq/java/...rierCollection

    dans ce cas on trie par chevaux mais admettons que l'on souhaite pouvoir trier soit par chevaux soit par marque quelle serait la logique dans ce cas?

    merci pour votre aide

    Tzoulou

  2. #2
    Membre confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2008
    Messages
    380
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2008
    Messages : 380
    Points : 480
    Points
    480
    Par défaut
    Bonjour,

    Il faut implémenter des classes qui implémente Comparable.
    Et ensuite appeler le tri en fonction des besoins en utilisant la méthode:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Collections.sort(liste_voitures, new ChevauxComparator());
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Collections.sort(liste_voitures, new MarqueComparator());

  3. #3
    Membre régulier
    Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    145
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Septembre 2005
    Messages : 145
    Points : 77
    Points
    77
    Par défaut
    donc je dois bien ajouter autant de comparator que j'ai de champs sur lesquels je souhaite trier.

    Merci pour l'info, je vais tester.

  4. #4
    Membre régulier
    Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    145
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Septembre 2005
    Messages : 145
    Points : 77
    Points
    77
    Par défaut
    Salut,

    je suis en train de tester, mais j'ai un petit souci.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    public class ModeleComparator implements Comparable
    dedans j'implemente la fonction CompareTo probleme cette fonction ne prend qu'un parametre.
    Donc ca veut qu'il faut que je fasse une seconde fonction compareTo avec mes 2 objet en parametre?

  5. #5
    Membre éclairé Avatar de Heimdal
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    549
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 549
    Points : 718
    Points
    718
    Par défaut
    implements Comparator

  6. #6
    Membre actif

    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    152
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 152
    Points : 264
    Points
    264
    Par défaut
    pour qu'un objet puisse être comparé à un à un autre il doit implémenté Comparable (c'est lui qui peut être comparé).
    Pour qu'un objet puisse comparé un objet, il doit implémenter Comparator (c'est lui qui compare).
    Les noms sont quand même bien choisi non !!

  7. #7
    Membre régulier
    Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    145
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Septembre 2005
    Messages : 145
    Points : 77
    Points
    77
    Par défaut
    meme avec un ArrayList?

    Dans mon cas j'ai besoin de comparer par rapport a différent critères, donc le comparable n'est pas possible, je dois faire n classe qui implemente comparator si je souhaite comparer n critere ?

  8. #8
    Expert éminent sénior
    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
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Salut,



    L'interface Comparable doit être implémenté par l'objet en lui-même afin de permettre la comparaison avec une autre instance, selon ce qu'on appelle l'ordre naturel. Ainsi tu ne peux avoir qu'une seule méthode de comparaison "naturelle"...

    L'interface Comparator permet de proposer des méthodes de comparaisons supplémentaires, en implémentant une méthode qui compare deux objets. Cela permet de définir d'autre ordre de comparaison, utilisable avec les méthodes sort() (entre autres...)

    a++

  9. #9
    Membre régulier
    Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    145
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Septembre 2005
    Messages : 145
    Points : 77
    Points
    77
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Collections.sort(cles, new PersonneComparator(personnes));

    si cles est un hashmap ma methode compare prend en parametre les deux clés du hashmap que je veux comparer.

    si cles est un arrayList ma methode compare prend en parametre les deux objets que je veux comparer.

    est ce que je me trompe?

  10. #10
    Membre confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2008
    Messages
    380
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2008
    Messages : 380
    Points : 480
    Points
    480
    Par défaut
    Citation Envoyé par TangoZoulou Voir le message

    si cles est un hashmap ma methode compare prend en parametre les deux clés du hashmap que je veux comparer.

    si cles est un arrayList ma methode compare prend en parametre les deux objets que je veux comparer.

    est ce que je me trompe?
    La méthode sort ne fonctionne pas avec une HashMap, le paramètre doit être une liste.
    Si cles est une ArrayList, oui la méthode compare prend en paramètre les objets à comparer.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    public class MyComparator implements Comparator<MonObjet> {
     
    	public int compare(MonObjet o1, MonObjet o2) {
    		// comparaison
    		// ....
    		return 0; // ou autre valeur...
    	}

Discussions similaires

  1. Trier un ArrayList selon deux criteres
    Par chamanR dans le forum Collection et Stream
    Réponses: 2
    Dernier message: 20/10/2010, 00h39
  2. Réponses: 3
    Dernier message: 07/10/2009, 19h23
  3. trier une arraylist selon un critère
    Par marion5515 dans le forum Collection et Stream
    Réponses: 6
    Dernier message: 15/03/2008, 20h25
  4. plusieurs selections selon sur colonne different critere
    Par richton95 dans le forum Requêtes
    Réponses: 2
    Dernier message: 27/01/2006, 17h25
  5. [TRIE] Trier un résultat selon certains termes
    Par narmataru dans le forum PostgreSQL
    Réponses: 4
    Dernier message: 04/07/2005, 18h42

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