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

avec Java Discussion :

Traitement de LinkedHashMap


Sujet :

avec Java

  1. #1
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2014
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2014
    Messages : 54
    Points : 47
    Points
    47
    Par défaut Traitement de LinkedHashMap
    Bonjour,

    J ai une question a laquelle je ne trouve pas de reponse et je suis completement bloque. c est pourquoi je me tourne vers vous en esperant en avoir une chez vous.

    j ai cree une classe duo tres simple qui a deux elements.

    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
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
     
    public  class Duo  {
     
    	int a;
     
    	int b;
     
     
    	public Duo(int a, int b){
     
    		this.a = a;
    		this.b = b;
    	}
     
     
    	/**
             * @return the a
             */
    	public int getA() {
    		return a;
    	}
     
     
    	/**
             * @param a the a to set
             */
    	public void setA(int a) {
    		this.a = a;
    	}
     
     
    	/**
             * @return the b
             */
    	public int getB() {
    		return b;
    	}
     
     
    	/**
             * @param b the b to set
             */
    	public void setB(int b) {
    		this.b = b;
    	}	
    }
    Apres, en partant d une liste [0,1,2,3,4], je cree une LinkedHashMap avec comme cle un Duo et comme valeur un Integer dans laquelle je stocke :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    Key : (0,1) -->>  Value 1
    Key : (0,2) -->>  Value 2
    Key : (0,3) -->>  Value 3
    Key : (0,4) -->>  Value 4
    Key : (1,2) -->>  Value 5
    Key : (1,3) -->>  Value 6
    Key : (1,4) -->>  Value 7
    Key : (2,3) -->>  Value 8
    Key : (2,4) -->>  Value 9
    Key : (3,4) -->>  Value 10
    ce que j obtiens par le code suivant :


    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
     
    LinkedHashMap<Duo, Integer> map = new LinkedHashMap<Duo, Integer>(); 
     
    	List<Integer> values = Arrays.asList(0,1,2,3,4);
     
    	int index = 1;
     
    	for(Integer value : values){
     
    		int position = values.indexOf(value); 
    		List<Integer> nextValues = values.subList(position + 1, values.size());
    		for(Integer nextValue : nextValues){
    			Duo duo = new Duo(value, nextValue);
    			map.put(duo, index);
    			index++;
    		}	
    	}
     
    	Iterator<Duo> iterator = map.keySet().iterator();
     
    	while (iterator.hasNext()) {
    		Duo key = iterator.next();
    		int a = key.getA();
    		int b = key.getB();
            System.out.println("Key : (" + a + ","+ b + ") -->> "+  " Value " + map.get(key));		
    	}
    Rien de magique jusque la !!

    Les ennuis commencent a partir du moment ou je veux recuperer le contenu de ma LinkedHashMap par le code suivant :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
           for(Integer value : values){
     
        	 int position = values.indexOf(value); 
     		 List<Integer> nextValues = values.subList(position + 1, values.size());
     
        	 for(Integer nextValue : nextValues){
        		 Duo duo = new Duo(value, nextValue);
        	     System.out.println("Value " + map.get(duo));			
     		}	
    	 }
    Sauf que je n obtiens que des Null. Et je ne sais pas ce qui se passe.

    N.B. Peut etre il y d autres moyens pour le faire mais je tiens a utiliser une boucle for (pour parcourir la liste values value par value) pour des considerations reltives au resultat final auquel je compte aboutir (et que je n ai pas presente ici pour ne pas etre trop long)..........

    Merci encore une fois de votre aide.

  2. #2
    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
    Il y a certaines contraintes à respecter lorsqu'on veut utiliser ses propres classes comme clés de Maps, ou dans un Set, ou comme critère de recherche quelconque.

    Il faut redéfinir les méthodes equals() et hashCode() de sorte que deux objets contenant les mêmes valeurs puissent reconnaître qu'ils sont égaux.
    Voir la FAQ : Pourquoi et comment redéfinir la méthode equals() ?
    Et entrée suivante pour hashCode().

    Pour hashCode(), il n'y a pas lieu de faire compliqué :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    @Override
    public int hashCode() {
      return getA() ^ getB();
    }
    sera bien suffisant.
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  3. #3
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2014
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2014
    Messages : 54
    Points : 47
    Points
    47
    Par défaut
    Merci de ta reponse.

    Sauf que je ne suis pas tout a fait sur d avoir compris ce qu il faut faire !

    En gros, ce que tu proposes est juste de rajouter les methodes overridés equals et hashcode a ma classe Duo et tout marchera bien ??

  4. #4
    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
    Oui... Je te propose de suivre les conseils de la FAQ, quoi.
    Tu ne pouvais pas deviner qu'il fallait aller la voir ni où chercher, mais maintenant que je t'ai donné le lien, il me semble que ça va de soi.
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  5. #5
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2014
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2014
    Messages : 54
    Points : 47
    Points
    47
    Par défaut
    D accord !

    Juste une petite question : Il n y absolument rien a rajouter a ma classe main ?

    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
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
     
     
    	public static void main(String[] args) {
     
    	LinkedHashMap<Duo, Integer> map = new LinkedHashMap<Duo, Integer>(); 
     
    	List<Integer> values = Arrays.asList(0,1,2,3,4);
     
    	int index = 1;
     
    	for(Integer value : values){
     
    		int position = values.indexOf(value); 
    		List<Integer> nextValues = values.subList(position + 1, values.size());
    		for(Integer nextValue : nextValues){
    			Duo duo = new Duo(value, nextValue);
    			map.put(duo, index);
    			index++;
    		}	
    	}
     
    	Iterator<Duo> iterator = map.keySet().iterator();
     
    	while (iterator.hasNext()) {
    		Duo key = iterator.next();
    		int a = key.getA();
    		int b = key.getB();
            System.out.println("Key : (" + a + ","+ b + ") -->> "+  " Value " + map.get(key));		
    	}
     
         for(Integer value : values){
     
        	 int position = values.indexOf(value); 
     		 List<Integer> nextValues = values.subList(position + 1, values.size());
     
        	 for(Integer nextValue : nextValues){
        		 Duo duo = new Duo(value, nextValue);
        	     System.out.println("Value " + map.get(duo));			
     		}	
    	 }
     
    	}

    Ca te parait correct ce que j ai ecrit ?

    Merci.

  6. #6
    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
    Ce serait pas du luxe de simplifier le code, mais il marche comme ça si on ajoute les méthodes nécessaires à la classe Duo.
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  7. #7
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2014
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2014
    Messages : 54
    Points : 47
    Points
    47
    Par défaut
    Parfait !

    Ca marche a merveille !!

    Merci bcp

  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,

    Citation Envoyé par thelvin Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    @Override
    public int hashCode() {
      return getA() ^ getB();
    }
    sera bien suffisant.
    A noter que pour le hashCode() depuis Java 7 on peut très bien utiliser Objects.hash() :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    @Override
    public int hashCode() {
      return Objects.hash(getA(), getB());
    }
    Ou depuis Java 5 avec Arrays.hashCode() :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    @Override
    public int hashCode() {
      return Arrays.hashCode(new int[]{getA(), getB()});
    }
    C'est surtout pratique lorsqu'on a plusieurs attributs et des objets pouvant être null...




    Sinon je vois deux autre soucis concernant la classe "Duo".
    Comme pour toute classe destiné à être utilisé en tant que clef d'une Map :
    • Elle devrait être immuable (non-modifiable), car si tu modifies une clef après l'avoir ajouté dans une Map elle deviendra inaccessible (puisque son hashcode change).
    • Il serait souhaitable qu'elle soit final, pour que l'immuabilité ne soit pas remis en cause par une sous-classe.



    a++

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

Discussions similaires

  1. Durée d'un traitement temps réel
    Par Almex dans le forum C
    Réponses: 5
    Dernier message: 29/03/2003, 14h15
  2. [directsound] boucle de traitement de son
    Par gargle dans le forum DirectX
    Réponses: 5
    Dernier message: 24/03/2003, 10h47
  3. Traitement d'un char* renvoyé par une DLL en C++
    Par LuluTchab dans le forum Langage
    Réponses: 4
    Dernier message: 22/03/2003, 21h48
  4. Rafraichissement de la fenetre pendant le traitement
    Par Bobx dans le forum Composants VCL
    Réponses: 5
    Dernier message: 20/02/2003, 15h13
  5. Matrice de filtrage ?
    Par gimlithedwarf dans le forum Traitement d'images
    Réponses: 2
    Dernier message: 24/08/2002, 09h44

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