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

C++ Discussion :

gestion des exceptions avec signal : perf ?


Sujet :

C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 106
    Par défaut gestion des exceptions avec signal : perf ?
    Bonjour,

    À de très rares occasions, sur certaines configurations exotiques mon programme est confronté à des crashs indépendant de mon code, qui sont due soit à un driver audio buggé, soit à un driver OpenGL buggé.
    Par exemple c'est arrivé avec le driver audio virtuel DFX Audio Enhancer, et avec un vieux driver AMD de 2010.
    Dans ce genre de cas, plutôt qu'un crash brutal avec un message d'erreur système j'aimerai afficher un message à l'utilisateur proposant un diagnostique possible.
    Pour ça j'ai trouvé la fonction signal:
    http://www.cplusplus.com/reference/csignal/signal/
    Qui semble faire parfaitement son office, puisque j'arrive maintenant à intercepter les rares cas qui me posaient problème.

    Cependant mon application fait de nombreux calculs en temps réel, et je voudrais être sur que l'interception de ces exceptions ne provoque pas de ralentissement du code en général, c'est à dire que ça n'induit pas un monitoring constant mais juste un déclenchement au moment même de l'exception. Savez vous ce qu'il en est ? Avez vous des infos la dessus ?

    Merci !

  2. #2
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2005
    Messages
    5 462
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Conseil

    Informations forums :
    Inscription : Février 2005
    Messages : 5 462
    Par défaut
    J'espère que vous n'utilisez pas cette cochonnerie sur plateforme Windows.
    Sinon, il n'y a pas d'overhead lié à cette fonctionnalité car cela se contente de mettre un pointeur dans une table système et d'appeler ce pointeur qu'au moment du signal.

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 106
    Par défaut
    Super, merci pour la réponse. Bien que je ne vois pas trop le rapport avec Windows; c'est un programme multiplateforme Windows/OS X, et signal() semble intercepter les exceptions comme il faut sur Windows.

  4. #4
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2005
    Messages
    5 462
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Conseil

    Informations forums :
    Inscription : Février 2005
    Messages : 5 462
    Par défaut
    Signal n'intercepte pas les exceptions.
    L'interception remonte vers l'OS, qui, on fonction de sa configuration, utilise une table planquée dans les données système du processus.
    Déjà, il y a plus de 20 ans, c'était le foutoir entre les Unix qui n'acceptaient pas la réentrance dans ces handlers et les autres qui se coltinaient un masque de bit pour le blocage temporaire des signaux, signal par signal.

    J'espère que ce foutoir c'est un peu résorbé, mais déjà que ces signaux n'ont jamais correctement fonctionnés sous Windows pré-NT, avec le sous-système tarte à la crème de POSIX sous Windows NT (pour notre cher Oncle Sam), c'est le genre de trucs qui ne fonctionnera très probablement que dans ce sous-système des plus anecdotique.

    Sous Windows, ce n'est clairement pas solution la plus simple et la plus puissante :
    WER
    https://msdn.microsoft.com/en-us/lib...=vs.85%29.aspx

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 106
    Par défaut
    Ah.. Quoi qu'il en soit, quand je lui fournis un driver foireux qui fait crasher mon application, le signal SIGABRT/SIGILL/SIGSEGV est bien redirigé vers ma fonction prédéfinie, du coup ça fait ce que je voulais. Du moment que ça n'impacte pas les perfs du reste de l'application, ça me va

Discussions similaires

  1. Gestion des exceptions avec JSF RI 1.2
    Par darsky dans le forum JSF
    Réponses: 5
    Dernier message: 12/11/2008, 12h25
  2. Gestion des exceptions avec le plugin ErrorHandler ?
    Par AzAt0th dans le forum Zend Framework
    Réponses: 7
    Dernier message: 07/01/2008, 14h31
  3. [POO] Gestion des exception avec php4
    Par mulot49 dans le forum Langage
    Réponses: 1
    Dernier message: 26/04/2007, 10h18
  4. Réponses: 2
    Dernier message: 01/12/2006, 19h55
  5. [vb.net]Gestion des exceptions avec les web services
    Par mvr dans le forum Windows Forms
    Réponses: 2
    Dernier message: 05/12/2005, 22h41

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