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 :

Information complémentaire sur les levées d'exception


Sujet :

avec Java

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2011
    Messages
    65
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 65
    Points : 65
    Points
    65
    Par défaut Information complémentaire sur les levées d'exception
    Bonjour à tous,

    Comme beaucoup ici, je débute en Java. Je suis en train de regarder le système de fonctionnement des levées d'exception.
    J'ai compris dans les grandes lignes le fonctionnement. Mais certains détails m'échappent. Par exemple sur cet extrait de code:

    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
    	public void setAge(int age) {
    		try {
    			if (age < 15) {
                                  MON CODE
    			}
    		} catch (Exception e) {
    			throw new IllegalArgumentException("Interdit au moins de 15 ans.");
    		}
     
    		this.age = age;
    	}
     
    	public void setAge(String age) throws ParseException {
    		try {
    			setAge(Integer.parseInt(age));
    		} catch (NumberFormatException e) {
    			throw new ParseException("Doit être un nombre", 42);
    		}
     
    	}
    Dans le cas de la première méthode, je lève l'exception IllegalArgumentException mais Eclipse ne m'oblige pas à spécifier cette levée d'exception dans la signature (pas besoin de throws IllegalArgumentException).
    A l'inverse, dans la méthode surchargée de setAge, Eclipse m'oblige à ajouter "throws ParseException".
    Pourquoi cette différence de traitement sur des méthodes quasi identique?
    Le fait que IllegalArgumentException soit une erreur héritant de RuntimeException et ParseException de Exception a-t-il un lien?

    Merci d'avance pour vos éclaircissement.
    Damien

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

    Citation Envoyé par austin57 Voir le message
    Le fait que IllegalArgumentException soit une erreur héritant de RuntimeException et ParseException de Exception a-t-il un lien?
    Oui, une RuntimeException (dite unchecked exception) ne nécessite pas de throws sur la signature de la méthode, et, par conséquence, n'obligera pas de catch dans le code appelant. Ce qui n'empêche pas de le faire éventuellement (mettre le throws explicitement).

    Citation Envoyé par austin57 Voir le message
    Eclipse m'oblige à ajouter "throws ParseException".
    Tu peux écrire ta redéfinition de méthode comme suit, ce qui te permettra d'éviter le throws ParseException:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    try {
       // ton code
    } catch(ParseException e) {
       throw new IllegalArgumentException(e);
    }
    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.

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2011
    Messages
    65
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 65
    Points : 65
    Points
    65
    Par défaut
    Bonjour,

    Et Merci à vous joel.drigo.
    C'est exactement le terme dont j'avais besoin pour saisir le problème...unchecked exception!!!
    Maintenant que je connais la différence checked/unchecked exception, c'est limpide.

    Encore merci!

  4. #4
    Membre chevronné
    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 : 75
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : retraité nostalgique Java SE

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 257
    Points : 1 855
    Points
    1 855
    Par défaut
    pour simplifier: il y a deux catégories d'exceptions: celles qui relèvent du "comportement normal" d'une application et celles qui relève du bug.
    exemple de comportement "normal": dans les spécifications d'une gestion d'un compte en banque, on crée une exception pour dire qu'on a dépassé le découvert autorisé. Ici on doit capter l'exception (checked exception)
    exemple de comportement "anormal": on a un bug qui déclenche un NullPointerException. Ici on ne peux pas nécessairement tout prévoir et on n'est pas obligé de capter l'exception.
    Après ça peut devenir délicat: un erreur sur un format de nombre appartient-t'il à une catégorie ou a une autre? (C'est là qu'on décidera entre NumberFormatException ou une autre exception "métier")
    Le principe général est assez délicat et mériterait des développements plus avancés sur la notion de "contrat" entre code appelant et code réalisant.
    mais bon commençons par du simple.
    J'ai des principes: je peux toujours trouver une bonne raison pour les contredire .... mais j'ai des principes!
    (mon excellent bouquin sur Java : https://eska-publishing.com/fr/livre...822407076.html)

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2011
    Messages
    65
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 65
    Points : 65
    Points
    65
    Par défaut
    J'ai consulté quelques sites sur le sujet
    La gestion des erreurs est effectivement plus complexe que prévu :p Notamment avec toutes ces classes qui héritent des autres. Mais c'est intéressant.

    D'ailleurs, en "jouant" avec les exceptions, une question m'est venue.
    Je vais créer un sujet pour cette question qui bien que parlant d'exception et plus lié à la pratique et j'aimerais bien avoir l'avis de personnes expérimentées.

    Alors à bientôt ^^
    Damien

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 13/03/2011, 11h21
  2. Information complémentaire sur l'action configure avant le make
    Par highsnoop dans le forum RedHat / CentOS / Fedora
    Réponses: 5
    Dernier message: 07/02/2011, 21h28
  3. Réponses: 1
    Dernier message: 20/11/2008, 15h39
  4. Information juridique sur les images
    Par c+cool dans le forum Droit
    Réponses: 8
    Dernier message: 29/06/2007, 14h04

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