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

VB.NET Discussion :

Capture des exceptions


Sujet :

VB.NET

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de gaetan13
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2010
    Messages
    90
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2010
    Messages : 90
    Par défaut Capture des exceptions
    Bonjour,
    J'ai une petite question concernant la capture et le gestion des exceptions. J'ai une classe qui gère la communication avec le port série. Je l'ai conçue pour qu'elle soit la plus autonome possible pour que les développeurs qui l'utilise aient le moins d'action possible à faire.

    Dans cette optique, elle capture les exception qu'elle cause elle même. Je m'explique : je laisse l'utilisateur capturer uniquement les exceptions qu'il a pu causer en utilisant une fonction etc... Si une exception est due par exemple à un problème de lecture d'un paquet entrant, l'exception sera mise dans le log mais l'utilisateur ne pourra pas la capturer. Idem si on déconnecte le câble, l'utilisateur ne pourra pas capturer l'exception que génère le SerialPort vu que je la capture dans ma classe.

    Je sais pas si c'est une bonne pratique et je vois pas trop comment faire pour pas que des exceptions soient déclenchées alors que l'utilisateur n'a rien demandé... Je me sens un peu coupable, est-ce une bonne pratique ?

  2. #2
    Expert éminent Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 202
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 202
    Par défaut
    tu peux masquer les exceptions, mais pour avoir une couverture fonctionnelle complète il faut alors des évènements pour ces cas
    comme ca si le développeur s'en fout il ne fait rien, s'il veut être averti il s'abonne
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  3. #3
    Modérateur

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    1 722
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 722
    Par défaut
    Bonjour,

    Des info détaillées sur les exceptions : Comprendre la philosophie des exceptions sous .NET
    Traductions d'articles :
    La mémoire en .NET - Qu'est-ce qui va où ?
    Architecture DAL de haute performance et DTO ; Version C# : Partie 1,Partie 2,Partie 3 — Version VB.NET : Partie 1,Partie 2,Partie 3
    N'hésitez pas à consulter la FAQ VB.NET, le cours complet de Philippe Lasserre et tous les cours, articles et tutoriels.

  4. #4
    Expert éminent Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 202
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 202
    Par défaut
    et tout dépend de ce que fais le code

    si c'est une classe qui s'occupe de dialoguer, sur la méthode qui envoie des données, il vaut mieux thrower s'il y a une erreur, un évènement n'ira pas

    par contre si c'est une classe qui s'occupe de transformer les informations (donc très autonome) tu peux exposer des propriétés avec l'état de la connexion, les valeurs obtenues, et donc lever un event lors de la déconnexion pour qu'un développeur puisse le notifier sur l'interface de l'appli
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  5. #5
    Membre confirmé Avatar de gaetan13
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2010
    Messages
    90
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2010
    Messages : 90
    Par défaut
    Merci pour votre réponse. Oui, actuellement je raise des événements pour informer de ce que l'exception a entrainer comme comportement (exemple déconnexion). Ça c'est pour la partie autonome. Et sinon quand l'utilisateur utilise des méthodes qui entrainent une action spécifique provoquant une exception je ne la bloque pas.

    Bon tout me semble en cohérence du coup Merci beaucoup

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

Discussions similaires

  1. [Exception]Gestion des exceptions, capture sur la classe.
    Par @lantis dans le forum Général Java
    Réponses: 9
    Dernier message: 22/07/2005, 19h43
  2. [JEditorPane]Captures des touches claviers
    Par splend_f dans le forum Agents de placement/Fenêtres
    Réponses: 5
    Dernier message: 17/05/2004, 14h57
  3. Capture d'exception dans un constructeur
    Par declencher dans le forum Composants VCL
    Réponses: 8
    Dernier message: 03/02/2004, 12h52
  4. [XMLRAD] gestion des exceptions
    Par pram dans le forum XMLRAD
    Réponses: 2
    Dernier message: 28/01/2003, 17h48
  5. c: gestion des exceptions
    Par vince_lille dans le forum C
    Réponses: 7
    Dernier message: 05/06/2002, 14h11

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