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 :

Redéfinition de equals


Sujet :

avec Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Avril 2006
    Messages
    853
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 853
    Par défaut Redéfinition de equals
    salut

    j'ai redéfinie equals pour un objets

    longVal étant de type long
    stringVal étant de type String

    j'obtient une java.lang.nullPointerException à l'endroit spécifié

    il y a une comparaison de 1 et 21 et ça crash

    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 boolean equals(Object o) {
            if (o == this) {
                return true;
            }
     
            if (o instanceof User) {
     
                User other = (User) o;
     
                if (this.longVal != other.longVal) { //crash ici
                    return false;
                }
     
                if (this.stringVal != null) {
                    if (!this.stringVal.equals(other.stringVal)) {
                        return false;
                    }
                }
     
                if (this.stringVal == null && other.stringVal!=null) {
                        return false;
                }
     
                return true;
            }
            return false;
        }
    une idée?

  2. #2
    Expert éminent
    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
    Billets dans le blog
    1
    Par défaut
    Salut,

    Tu es sûr du code ? Parce que théoriquement c'est impossible d'avoir une NPE sur cette ligne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if (this.longVal != other.longVal) { //crash ici
    Seul other pourrait être null, or dans ce cas là le instanceof renverrait false...


    a++

  3. #3
    Membre émérite
    Avatar de divxdede
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    525
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Avril 2004
    Messages : 525
    Par défaut
    La seule autre explication serait
    other.longVal soit un Long
    this.longVal soit un long

    Le NullPointerException frapperait lors de l'unboxing.
    sauf que other et this semble être de même type, donc c'est à priori impossible que la déclaration de longVal soit differente.

  4. #4
    Membre éclairé
    Inscrit en
    Avril 2006
    Messages
    853
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 853
    Par défaut
    une image


    et le null me renvoie bien à la ligne spécifié...

  5. #5
    Membre éclairé
    Inscrit en
    Avril 2006
    Messages
    853
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 853
    Par défaut
    dans le code j'ai bien

    long longVal;

  6. #6
    Membre émérite
    Avatar de divxdede
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    525
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Avril 2004
    Messages : 525
    Par défaut
    Ton débugger à réussi à évaluer other.longVal donc il n'y a pas eu de nullpointer de ce coté là. this.longVal ne peut pas lever cette exception non plus...
    Le débugger ne serait pas arretté a cette ligne uniquement parceque tu as mis un break-point (un point d'arret) ?

    Tu peu nous montrer la "stack trace" de l'exception ?

  7. #7
    Membre éclairé
    Inscrit en
    Avril 2006
    Messages
    853
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 853
    Par défaut
    Citation Envoyé par divxdede Voir le message
    Ton débugger à réussi à évaluer other.longVal donc il n'y a pas eu de nullpointer de ce coté là. this.longVal ne peut pas lever cette exception non plus...
    Le débugger ne serait pas arretté a cette ligne uniquement parceque tu as mis un break-point (un point d'arret) ?

    Tu peu nous montrer la "stack trace" de l'exception ?

    la valeur est inséré de cette façon
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    oldRoot = (Long) resultMap.get("idConditionRoot");
    la méthode est appelé de cette façon
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    if (!idRoot.equals(oldRoot))
    comment ont fait pour obtenir cette stack trace?

  8. #8
    Expert éminent
    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
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par robert_trudel Voir le message
    la valeur est inséré de cette façon
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    oldRoot = (Long) resultMap.get("idConditionRoot");
    Donc ce n'est pas un objet User et on ne devrait pas rentrer dans le if du instanceof



    Citation Envoyé par robert_trudel Voir le message
    comment ont fait pour obtenir cette stack trace?
    Le stacktrace est affiché sous le message de l'exception.

    a++

  9. #9
    Membre expérimenté Avatar de DarkMolo
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    207
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : Maroc

    Informations forums :
    Inscription : Juillet 2006
    Messages : 207
    Par défaut
    Salut,

    D'aprés ce que tu dis, on peut affirmer que other est nul !

    Si tu pouvais nous montrer comment t'as appellé la méthode et avec quels paramétres.

  10. #10
    Membre Expert
    Avatar de CheryBen
    Inscrit en
    Mai 2005
    Messages
    1 599
    Détails du profil
    Informations personnelles :
    Âge : 43

    Informations forums :
    Inscription : Mai 2005
    Messages : 1 599
    Par défaut
    Citation Envoyé par DarkMolo Voir le message
    D'aprés ce que tu dis, on peut affirmer que other est nul !
    Non puisque o instanceof User est vrai, c'est un cas cornellien

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

Discussions similaires

  1. Map et redéfinition du equals et hashCode
    Par jojodu31 dans le forum Collection et Stream
    Réponses: 18
    Dernier message: 02/12/2011, 15h33
  2. redéfinition equals, hashmap et get
    Par oc_alex86 dans le forum Collection et Stream
    Réponses: 4
    Dernier message: 29/05/2007, 15h52
  3. Redéfinition de equals
    Par eureka dans le forum Langage
    Réponses: 15
    Dernier message: 21/04/2006, 21h25
  4. [Héritage] Redéfinition méthode
    Par petit-ourson dans le forum Langage
    Réponses: 9
    Dernier message: 06/05/2004, 16h06
  5. [MFC] redéfinition de BEGIN_MESSAGE_MAP
    Par SethPech dans le forum C++Builder
    Réponses: 2
    Dernier message: 10/03/2004, 13h59

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