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 :

Redéfinir equals et hashcode


Sujet :

Langage Java

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2008
    Messages : 4
    Par défaut Redéfinir equals et hashcode
    Bonjour,

    tout d'abord désolé pour le titre de ce message, qui sonne comme vu et revu.
    Pourtant, je n'ai pas trouvé réponse à ma question.

    Il est bien expliqué dans hashcode et equals qu'il faille redéfinir la méthode "hashcode" d'un objet après redéfinition de la méthode "equals" pour respecter le contrat.

    Or, il faut que c'est redéfinition se fasse également dans le respect du contrat.
    Comme dit dans la Javadoc "Whenever it is invoked on the same object more than once during an execution of a Java application, the hashCode method must consistently return the same integer, provided no information used in equals comparisons on the object is modified".
    Définir le hashcode sur la valeur des attributs ne respect donc pas le contrat.

    Quel est alors la meilleure méthode à utiliser pour redéfinir la méthode equals d'un objet, afin que deux objets ayant des attributs égaux soit égaux, tout en état standard-compliant ?

    Merci.

  2. #2
    Expert éminent
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Belgique

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Par défaut
    tu calcule le hashcode en fonction des valeurs utilisées dans le equals, uniquement.

  3. #3
    Rédacteur
    Avatar de CyberChouan
    Homme Profil pro
    Directeur technique
    Inscrit en
    Janvier 2007
    Messages
    2 752
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Janvier 2007
    Messages : 2 752
    Par défaut
    Exprimé mathématiquement, le contrat doit respecter :

    (a.equals(b)) => (a.hashcode() == b.hashcode())

    Attention, la réciproque n'est pas nécessairement vraie
    Avant de poster, pensez à regarder la FAQ, les tutoriaux, la Javadoc (de la JRE que vous utilisez) et à faire une recherche
    Je ne réponds pas aux questions techniques par MP: les forums sont faits pour ça
    Mes articles et tutoriaux & Mon blog informatique

  4. #4
    Expert éminent
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Belgique

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Par défaut
    et il est recommandé que la probabilité de a.hashcode()==b.hashcode sous condition (!a.equals(b)) soit la plus faible possible

  5. #5
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2008
    Messages : 4
    Par défaut
    j'ai bien compris tout cela.

    Mais il est également indiqué que le Hashcode d'un objet doit rester le même lors de plusieurs invocation successives...
    Or, s'il l'on re-modifie les attributs d'un objet A égal (au sens définis dans ma méthode "equals" surchargé) à un objet B pour le rendre égal à un autre objet C, le hashcode de A doit alors être le même que celui de C, mais également de B si la méthode hashcode avait été initialement appelée.

    Le serpent se mort il la queue ou j'ai loupé quelque chose dans l'histoire ?

  6. #6
    Expert éminent
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Belgique

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Par défaut
    si deux objet sont égaux au regard de equals(), alors leur hashcode doivent ausi être égaux (cà c'est pour le contrat equals/hashcode). Il n'est pas stipulé dans hashcode que celui-ci doit rester les même. Il est jsute stipulé que celui-ci doit rester le même *si* les éléments pris en compte par la méthode equals sont restés le mêmes.

  7. #7
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2008
    Messages : 4
    Par défaut
    Je sais que mon niveau d'anglais est moyen, mais il me semble que "Whenever it is invoked on the same object more than once during an execution of a Java application, the hashCode method must consistently return the same integer, provided no information used in equals comparisons on the object is modified." n'est pas en accord avec ce que tu dis.

  8. #8
    Membre émérite
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    764
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 764
    Par défaut
    Citation Envoyé par maxired Voir le message
    Mais il est également indiqué que le Hashcode d'un objet doit rester le même lors de plusieurs invocation successives...
    Citation Envoyé par maxired Voir le message
    "Whenever it is invoked on the same object more than once during an execution of a Java application, the hashCode method must consistently return the same integer, provided no information used in equals comparisons on the object is modified."
    Le hashcode doit rester le même lors de 2 invocations successives à condition qu'aucune information utilisée par la méthode equals n'ait été modifiée.


    Citation Envoyé par maxired Voir le message
    Si l'on re-modifie les attributs d'un objet A égal (au sens définis dans ma méthode "equals" surchargé) à un objet B pour le rendre égal à un autre objet C, le hashcode de A doit alors être le même que celui de C, mais également de B si la méthode hashcode avait été initialement appelée.
    Tu as un objet A égal (au sens de equals) à un objet B. Son hashcode vaut hash1 et est le même que celui de B.
    Tu modifies A pour le rendre égal (au sens de equals) à C. Son hashcode vaut alors hash2 et est le même que celui de C.
    Alors certes, si hash1 et hash2 sont différents, le hashcode de A a été modifié. Mais dans ce cas B et C sont différents (au sens de equals) (sinon ils auraient le même hashcode) donc lors de la modification de A tu as forcément du modifier des informations intervenant dans la méthode equals ! La phrase que tu cites est bien respectée...

  9. #9
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2008
    Messages : 4
    Par défaut
    merci et mea culpa

  10. #10
    Expert éminent
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Belgique

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Par défaut
    et n'oublie pas le bouton

Discussions similaires

  1. fonction equals() et hashcode()
    Par mdh12 dans le forum Débuter avec Java
    Réponses: 3
    Dernier message: 24/10/2010, 13h47
  2. Equaliz 0.2 : Des methodes equals et hashcode orienté métier
    Par benjamalin dans le forum API standards et tierces
    Réponses: 0
    Dernier message: 16/08/2010, 14h49
  3. Réponses: 0
    Dernier message: 26/11/2007, 15h47
  4. Modifier le template de equals et hashCode
    Par Baptiste Wicht dans le forum Eclipse Java
    Réponses: 4
    Dernier message: 13/04/2007, 15h26
  5. [Optim Code]equals and hashCode are not paired
    Par anitshka dans le forum Débuter avec Java
    Réponses: 3
    Dernier message: 15/09/2006, 23h25

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