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

Java Discussion :

Collection: le tri d'une PriorityQueue par un Comparator


Sujet :

Java

  1. #1
    Nouveau membre du Club
    Inscrit en
    Novembre 2008
    Messages
    28
    Détails du profil
    Informations forums :
    Inscription : Novembre 2008
    Messages : 28
    Points : 30
    Points
    30
    Par défaut Collection: le tri d'une PriorityQueue par un Comparator
    Bonjour,

    Je cherche à comprendre le fonctionnement de PriorityQueue:
    je ne comprends le fait qu'elle soit 'sorted' par ordre naturel:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    PriorityQueue<String> pq = new PriorityQueue<String>();
    		pq.add("e");
    		pq.add("a");
    		pq.offer("z");
    		System.out.println(pq);
                    ==>[a, e, z]
    MAIS,supposant que je construise une collection d'objets T:

    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
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    public class T implements Comparator<T>{
    int index;String nom;	
     
    	public static void main(String[] args) {	 	
    		PriorityQueue<T> pq = new PriorityQueue<T>();
     
    		T p1=new T();
    		p1.index=1;p1.nom="un";
     
    		Tp2=new T();
    		p2.index=1;p2.nom="deux";
     
    		Tp3=new T();
    		p3.index=3;p3.nom="trois";
     
    		pq2.add(p3);
    		pq2.add(p2);
    		pq2.add(p1);
     
    		System.out.println(pq2);
    	}
     
    	@Override
    	public int compare(To1, To2) {
    		return (o1.index > o2.index)? -1:1;
     
    	}
    }
    Je dois normalement trier selon l'ordre inverse des index
    Mais à l’exécution, j'ai une exception:
    Exception in thread "main" java.lang.ClassCastException: collection.T cannot be cast to java.lang.Comparable

    Quelqu'un a une idée ,svp


    Cordialement

  2. #2
    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,

    Citation Envoyé par limalima Voir le message
    Mais à l’exécution, j'ai une exception:
    Exception in thread "main" java.lang.ClassCastException: collection.T cannot be cast to java.lang.Comparable
    Une exception qui te dit quel est le problème : tu ne doit pas implémenter Comparator mais Comparable !!


    a++

  3. #3
    Modérateur
    Avatar de Gugelhupf
    Homme Profil pro
    Analyste Programmeur
    Inscrit en
    Décembre 2011
    Messages
    1 320
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Analyste Programmeur

    Informations forums :
    Inscription : Décembre 2011
    Messages : 1 320
    Points : 3 741
    Points
    3 741
    Billets dans le blog
    12
    Par défaut
    Aussi, tu n'as pas le droit de faire "new T()" en Java.
    N'hésitez pas à consulter la FAQ Java, lire les cours et tutoriels Java, et à poser vos questions sur les forums d'entraide Java

    Ma page Developpez | Mon profil Linkedin | Vous souhaitez me contacter ? Contacter Gokan EKINCI

  4. #4
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par Gugelhupf Voir le message
    Aussi, tu n'as pas le droit de faire "new T()" en Java.
    Salut,

    tu t'es fait abusé par le nom peu conventionnel de la classe (et de plus confusant avec un nom courant de paramètre générique) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    public class T implements Comparator<T>{
    mais on a parfaitement le droit d'instancier une classe qui s'appelle T (et qui n'a qu'un constructeur implicite sans argument) en appelant

    .
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

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

Discussions similaires

  1. Tri d'une matrice par colonne
    Par bigamine5 dans le forum Débuter avec Java
    Réponses: 7
    Dernier message: 23/10/2012, 16h54
  2. Tri d'une liste par date
    Par developpeur_débutant dans le forum Général Java
    Réponses: 5
    Dernier message: 24/11/2011, 10h09
  3. Tri d'une vue par n° de commande
    Par juju05 dans le forum Langage SQL
    Réponses: 16
    Dernier message: 21/06/2011, 18h23
  4. [VBA-E]Tri d'une plage par une colonne
    Par illight dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 07/02/2006, 10h53
  5. Tri d'une zone de liste par bouton
    Par illight dans le forum Access
    Réponses: 7
    Dernier message: 09/11/2005, 19h39

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