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 :

NullPointerException ou IllegalArgumentException ?


Sujet :

Langage Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Étudiant
    Inscrit en
    Avril 2009
    Messages
    171
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2009
    Messages : 171
    Par défaut NullPointerException ou IllegalArgumentException ?
    Bonjour,

    Je me pose un problème d'ordre sémantique sur les types d'exception NullPointerException et IllegalArgumentException.

    J'ai une méthode avec en paramètre un objet. Dans le corps de cette méthode je voudrai déclencher volontairement une exception quand ce paramètre est null.
    Perso, j'aurai plutôt levé une exception de type NullPointerException. Mais étant donné que c'est un paramètre de ma méthode je me demande s'il ne vaut pas mieux utiliser IllegalArgumentException.

    Qu'en pensez vous ?

    Nicolas.

  2. #2
    Membre émérite 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
    Par défaut
    Salut,

    La théorie voudrait plutôt qu'on utilise une NPE dans ce cas là.
    Perso, je préfère lever des IAE avec un message clair.
    Je suppose que c'est avant tout une question de gout.

    Voyons ce qu'en pense les autres.

  3. #3
    Modérateur

    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    12 582
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 12 582
    Par défaut
    Tu veux lancer une exception quand le pointeur est null.
    Ça signifie que passer un pointeur null en paramètre de la méthode est une erreur de programmation.
    Donc la logique de la chose voudrait que ce soit un NullPointerException.

    A priori ce n'est pas vraiment important. J'ai tendance à penser qu'un NullPointerException indique le problème plus directement que ne le ferait un IllegalArgumentException : Object is null. Mais les deux permettent de repérer le soucis, alors pas grave.
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  4. #4
    Membre Expert
    Avatar de professeur shadoko
    Homme Profil pro
    retraité nostalgique Java SE
    Inscrit en
    Juillet 2006
    Messages
    1 257
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 76
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : retraité nostalgique Java SE

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 257
    Par défaut
    pour moi pas de doute: c'est une IllegalArgumentException.
    pourquoi?
    à mon humble avis les RuntimeException existent en deux saveurs:
    - les vraies RuntimeException qui sont le résultat d'une erreur d'exécution détectée par la machine virtuelle
    - les préconditions non remplies qui sont sous la responsabilité du code appelant. IllegalArgumentException et autres.

    on peut approfondir la discussion en arguant que dans le premier cas c'est le code réalisant qui est fautif alors que dans le second c'est le code appelant qui ne remplit pas sa part du contrat et donc on le signale dument.
    I

  5. #5
    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 on suit la logique de l'api java. Quand un argument est incorrect car null, c'est bien souvent le nullpointerexception qui est déclenché. La différence entre le null "prévu" et le null pas vraiment pris en charge se joue dans le message du NPE ainsi que dans la documentation de la méthode précisant qu'elle peut déclencher un NPE

  6. #6
    Membre Expert
    Avatar de professeur shadoko
    Homme Profil pro
    retraité nostalgique Java SE
    Inscrit en
    Juillet 2006
    Messages
    1 257
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 76
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : retraité nostalgique Java SE

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 257
    Par défaut
    en fait cela se situe à un autre niveau: ou bien on laisse le NullPointerException se produire (et on dit qu'il y a un risque si on a un argument pas correct) ou bien on ne le laisse pas se produire parceque c'est pas la peine d'aller jusque là.
    C'est donc une décision au niveau de la réalisation du code, mais là où j'ai des doutes c'est: est-il pertinent de déclencher soi-même une NullPointerException?
    Je ne le pense pas.
    Si on fait des contrôles de préconditions je pense qu'il faut bien l'affirmer.

  7. #7
    Membre chevronné
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    299
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Janvier 2009
    Messages : 299
    Par défaut
    Bonjour,

    je ne suis pas d'un niveau suffisant pour parler d' "ordre sémantique", mais par contre, je suis de l'avis de thelvin dans le sens ou le NPE me semble permettre une identification plus rapide du problème.

  8. #8
    Membre émérite 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
    Par défaut
    Et moi je dit, la première chose a respecter est la spec
    +1

    Après je trouve qu'un message clair sur la nullité d'un attribut dans une IAE permet de détecter le problème aussi vite et permet de différencier les erreurs d'utilisation des dev du projet et ceux d'utilisation d'une API.
    Donc pour résumer j'aurais tendance à suivre cette logique:

    - dev d'une API: NPE (on suit les specs à la lettre)
    - dev d'un soft qqcq: IAE

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


    Pour moi le NPE est le plus précis et le plus clair. Il n'y a pas à chercher midi à 14h !

    Bien sûr il faut accompagner cela d'un message clair et explicite du style : "xxxx must not be null".


    a++

  10. #10
    Membre Expert
    Avatar de professeur shadoko
    Homme Profil pro
    retraité nostalgique Java SE
    Inscrit en
    Juillet 2006
    Messages
    1 257
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 76
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : retraité nostalgique Java SE

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 257
    Par défaut
    he he:ok ok pas taper pas taper! .... et si je fais ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    class NullParameterException extends NullPointerException {
    }
    trouverais je grace à vos yeux?
    (Mon objectif étant de toujours distinguer les types de RuntimeException: il est vrai que dans ce cas j'aurais plutot tendance à hériter de IllegalArgumentException qui est la vraie sémantique -quoiqu'on en dise-)

  11. #11
    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
    Citation Envoyé par professeur shadoko Voir le message
    trouverais je grace à vos yeux?
    Nan, t'as travaillé comme un cochon en oubliant de redéfinir tous les constructeurs

  12. #12
    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 professeur shadoko Voir le message
    (Mon objectif étant de toujours distinguer les types de RuntimeException: il est vrai que dans ce cas j'aurais plutot tendance à hériter de IllegalArgumentException qui est la vraie sémantique -quoiqu'on en dise-)
    Disons que fondamentalement il n'est pas choquant de remonter une IllegalArgumentException... mais que perso dans ce cas précis je m'attendrais plus à une NPE...

    Pour moi un IllegalArgumentException survient lorsqu'un argument à une valeur incorrect, alors qu'une référence null représente une "absence de valeur"

    Quand à la spécialisation, c'est surtout pratique dans les cas où cela peut entrainer un traitement spécifique.


    Mais bon cela reste du chipotage...


    @Heimdal : je n'aime pas trop l'idée de différencier API et soft concernant la gestion des exceptions. Il vaut mieux avoir quelque chose de cohérent.

    @professeur shadoko : je n'ai pas compris ton passage sur les "OOpsSpecsPourravesException" !?!? C'est une notion spécifique à C# ??


    a++

Discussions similaires

  1. [Débutant]NullPointerException
    Par Crazyblinkgirl dans le forum Langage
    Réponses: 4
    Dernier message: 18/08/2004, 13h58
  2. [Exception]Double buffering & NullPointerException
    Par Seiya dans le forum API standards et tierces
    Réponses: 25
    Dernier message: 09/07/2004, 18h41
  3. Réponses: 10
    Dernier message: 29/06/2004, 22h25
  4. Heritage et NullPointerException
    Par Assiobal dans le forum Langage
    Réponses: 6
    Dernier message: 18/06/2004, 16h35
  5. JPanel & getGraphics() : NullPointerException
    Par dingoth dans le forum Composants
    Réponses: 7
    Dernier message: 21/05/2004, 15h56

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