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 :

Avoid Catching Throwable


Sujet :

Langage Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Juillet 2006
    Messages
    47
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 47
    Par défaut Avoid Catching Throwable
    Bonjour,

    je travaille avec sonar pour auditer la qualité de mon code et je suis tombeé sur la métrique suivante :
    Avoid Catching Throwable : A catch statement should never catch throwable since it includes errors.

    !je récupère cette erreur sur la portion de code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    try {
    	super.finalize();
    } catch (Throwable exception) {
    	LOG.error(exception);
    }
    Y-a t'il une solution pour contourner le problème ?

  2. #2
    Membre Expert
    Profil pro
    Inscrit en
    Août 2006
    Messages
    3 276
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 3 276
    Par défaut
    Oui catcher uniquement des classes dérivant d'Exception.
    Une Error est une erreur grave qu'on ne doit pas essayer catcher, car l'application n'est plus en mesure de fonctionner.

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


    La solution est de virer le try/catch qui ne sert à rien !
    Tu n'en as pas besoin dans la méthode finalize()...

    a++

  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
    Avoid Catching Throwable : A catch statement should never catch throwable since it includes errors.

    à part le fait que le catch ne s'applique pas dans le cas d'espèce je trouve la recommandation un tantinet contradictoire (avoid/never). Je rappelle toujours la recommandation d'Oscar Wilde: "appuyez-vous sur vos principes il finiront bien par céder!".
    (oui dans certains cas -pas courants, courants- ça peut être pertinent de faire catch de Throwable et, en particulier, de récolter des Errors )

Discussions similaires

  1. Checkstyle catch Throwable prohibited
    Par allstar dans le forum Général Java
    Réponses: 6
    Dernier message: 11/02/2009, 17h39
  2. [Exception] récupération de la stack trace d'une Throwable
    Par totof2308 dans le forum API standards et tierces
    Réponses: 6
    Dernier message: 14/05/2004, 14h49
  3. [try-catch] relancer les instruction du bloc try
    Par nounou dans le forum Langage
    Réponses: 11
    Dernier message: 12/05/2004, 11h23
  4. [HttpClient] comportement bizarre, saute des catch()...
    Par iubito dans le forum Développement Web en Java
    Réponses: 4
    Dernier message: 04/02/2004, 15h25
  5. Exception & Try..catch
    Par PurL dans le forum C++Builder
    Réponses: 2
    Dernier message: 11/12/2002, 15h35

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