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 :

Anti-pattern : exception métier


Sujet :

Langage Java

  1. #41
    Membre actif
    Inscrit en
    Juin 2008
    Messages
    189
    Détails du profil
    Informations forums :
    Inscription : Juin 2008
    Messages : 189
    Points : 268
    Points
    268
    Par défaut
    @LittleBean

    Pour cet exemple précis, la deuxième méthode ne m'a pas l'air adéquate car :

    - la méthode retrait peut être considerée comme une opération atomique qui gère déjà tous les cas d'erreurs
    - la méthode retrait peut toujours péter via une exception -> Il y a 2 fois le même traitement d'erreur qui va se retrouver quelque part.
    Puisqu'évidemment, la ligne "if (compteEnBanque.getSolde() > demandeRetrait)" ne garantie pas du tout que l'on puisse effectuer le retrait". Donc que l'exception de dépassement ne sera pas levé

  2. #42
    Membre averti
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    338
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2008
    Messages : 338
    Points : 402
    Points
    402
    Par défaut
    Citation Envoyé par Uther Voir le message
    C'est vrai que j'ai un peu trop simplifié mon exemple, mais on pourrait garder toutes les infos (sauf la stacktrace).
    Je trouve ta solution pas mal, à condition d'avoir un message d'erreur bien précis qui détaille le nom de la méthode et le pourquoi de l'erreur particulièrement si on se trouve dans un boucle

  3. #43
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Citation Envoyé par adiGuba Voir le message
    Oui mais là on est en plein dans l'anti-pattern : à quoi peut bien servir une exception qui ne contiendrait aucune info sur l'erreur !?

    a++
    Je répondrais pas une classe de l'api java qui le fait

    java.lang.OutOfMemoryError

  4. #44
    Expert éminent sénior
    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
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par tchize_ Voir le message
    Je répondrais pas une classe de l'api java qui le fait

    java.lang.OutOfMemoryError
    OutOfMemoryError génère bien un stacktrace

    a++

  5. #45
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    t'es sur? alors c'est la manière don la jvm le déclenche qui empeche le stacktrace, je les ai toujours vu sans stacktrace, et pour cause, pas assez de mémoire que pour créer le stacktrace.

  6. #46
    Expert éminent sénior
    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
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par tchize_ Voir le message
    t'es sur? alors c'est la manière don la jvm le déclenche qui empeche le stacktrace, je les ai toujours vu sans stacktrace, et pour cause, pas assez de mémoire que pour créer le stacktrace.
    Tu me mets le doute et j'ai vérifié j'ai bien un stacktrace, mais apparemment ce n'était pas le cas avant Java 5u12 : http://bugs.sun.com/bugdatabase/view...bug_id=4753347

    a++

  7. #47
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    effectivment, mes Out of memory error arrivent souvent en prod, et on est à un jvm < à cette révision (et en plus en saveur HP-UX, la blague!)

    Merci d'avoir déterré çà

Discussions similaires

  1. Réponses: 10
    Dernier message: 06/10/2010, 17h06
  2. Les exceptions métiers
    Par zoaax dans le forum Général Dotnet
    Réponses: 12
    Dernier message: 15/04/2010, 14h31
  3. singleton == anti pattern?
    Par yan dans le forum C++
    Réponses: 5
    Dernier message: 17/04/2008, 14h17
  4. Réponses: 11
    Dernier message: 26/09/2007, 11h28

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