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 d'exception avec la classe exception


Sujet :

C++

  1. #1
    Membre expert
    Avatar de alassanediakite
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2006
    Messages
    1 599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Mali

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2006
    Messages : 1 599
    Points : 3 590
    Points
    3 590
    Billets dans le blog
    8
    Par défaut Gestion d'exception avec la classe exception
    Salut
    Pourquoi dans ce code, l'erreur de division par zéro n'est pas interceptée?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    int a;
    cin>>a;//je rentre zéro (0)
    try
    {a=1/a;}
    catch(exception e){cout<<e.what();}
    Si la classe exception ne gère par la division par zéro, quelle classe interne peu-t-on utiliser?
    Merci d'avance.
    @+
    Le monde est trop bien programmé pour être l’œuvre du hasard…
    Mon produit pour la gestion d'école: www.logicoles.com

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

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

    Informations forums :
    Inscription : Février 2005
    Messages : 5 074
    Points : 12 120
    Points
    12 120
    Par défaut
    On ne catche jamais "exception".
    Et on ne catche que pour faire un traitement de l'exception, et loguer/afficher l'exception, c'est pas un traitement.
    On ne catche que les exceptions que l'on sait traiter, donc jamais "exception".

    Une division par zéro ne "génère" pas une exception C++, mais une interruption logicielle.

    https://stackoverflow.com/questions/...-studio-2008-c
    La réponde de Volodymyr Frytskyy est ma préférée.

  3. #3
    Membre expert
    Avatar de alassanediakite
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2006
    Messages
    1 599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Mali

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2006
    Messages : 1 599
    Points : 3 590
    Points
    3 590
    Billets dans le blog
    8
    Par défaut
    Salut et merci pour la reponse.
    Citation Envoyé par bacelar Voir le message
    On ne catche jamais "exception".
    Et on ne catche que pour faire un traitement de l'exception, et loguer/afficher l'exception, c'est pas un traitement.
    On ne catche que les exceptions que l'on sait traiter, donc jamais "exception".
    J'ai toujours vu la gestion des erreurs comme une manière de s'assurer que le programme ne plante pas.
    Ainsi en plus du traitement des exceptions les plus probables il faut prévoir un cas général...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    try
    {...}
    catch(cas1 e1){...}
    catch(cas2 e2){...}
    ...
    catch(cas général eg){...}
    J'ai tenté la solution de Volodymyr Frytskyy sur VS2010 mais l'exception n'est pas gérée et le lien donne une documentation à télécharger.
    Citation Envoyé par bacelar Voir le message
    Une division par zéro ne "génère" pas une exception C++, mais une interruption logicielle.
    Alors questions:
    • Il y a-t-il un solution unique pour capter toutes les exceptions en C++
    • Sinon comment capter la division par zéro sans vérifier les opérandes?

    @+
    @+
    Le monde est trop bien programmé pour être l’œuvre du hasard…
    Mon produit pour la gestion d'école: www.logicoles.com

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

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

    Informations forums :
    Inscription : Février 2005
    Messages : 5 074
    Points : 12 120
    Points
    12 120
    Par défaut
    J'ai toujours vu la gestion des erreurs comme une manière de s'assurer que le programme ne plante pas.
    Et mettre le problème sous le tapis ?
    C'est de la connerie en barre.

    Quand il y a une erreur que le programmeur n'a pas prévu, on laisse mourir l'application et l'OS génèrera automatiquement un fichier de dump pour que le programmeur ait des informations sur le problème non prévu.

    Ainsi en plus du traitement des exceptions les plus probables il faut prévoir un cas général...
    NON !!!
    Quand on ne sait pas ce que l'on catche ou comment le traiter, on ne catche pas, un point c'est tout.
    Si votre code catche une erreur mais que le code appelant le votre, lui, c'est vraiment comment gérer cette erreur, il faut comment ? (Il l'a dans le baba)

    J'ai tenté la solution de Volodymyr Frytskyy sur VS2010 ... le lien donne une documentation à télécharger.
    C'est un lien cassé.
    https://cppcodetips.wordpress.com/20...eptions-in-vc/
    Vous pouvez aussi lire les autres réponses du sujet sur StackOverflow qui donnent pas mal de détails.

    J'ai tenté la solution de Volodymyr Frytskyy sur VS2010 mais l'exception n'est pas géré
    Vous avez bien compris que dans "catch(...)", c'était bien LITTÉRALEMENT "..." et pas autre chose ?

    Il y a-t-il un solution unique pour capter toutes les exceptions en C++
    Oui, mais je ne le dirai pas, parce que c'est une connerie.
    Et une division par 0, ce n'est pas une exception C++, c'est une erreur qui déclenche une interruption logicielle, pas une exception C++. (BIS)

    Sinon comment capter la division par zéro sans vérifier les opérandes?
    Donc comment faire une connerie ?
    Parce que vérifier la validité des entrées/sorties utilisateurs ou des paramètres passés en argument d'une fonction, c'est normalement le minimum syndical du moindre code un tantinet sérieux.
    On vous a déjà données une ribambelle de solutions dans le sujet sur StackOverflow :
    - utilisation de "__try ... __except" pour récupérer les SEH
    - mise en place d'un handler sur les SEH
    - demander au compilateur de convertir les SEH en machin "catchable" par du C++
    - ...

    Mais, bon, tout ça pour coder salement, bof, bof.

  5. #5
    Membre expert
    Avatar de alassanediakite
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2006
    Messages
    1 599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Mali

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2006
    Messages : 1 599
    Points : 3 590
    Points
    3 590
    Billets dans le blog
    8
    Par défaut
    Salut
    Merci de l'effort.
    @+
    Le monde est trop bien programmé pour être l’œuvre du hasard…
    Mon produit pour la gestion d'école: www.logicoles.com

  6. #6
    Expert éminent sénior
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 614
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 614
    Points : 30 626
    Points
    30 626
    Par défaut
    Salut,

    De manière générale, si le développeur d'une fonction ne vérifie pas les informations fournies par l'utilisateur du programme, c'est une erreur de la part du développeur (il faut partir du principe que l'utilisateur est un imbécile distrait, qui n'attend que l'occasion de faire une connerie ... )

    Une erreur de la part du développeur, ce n'est pas quelque chose que l'on peut "planquer sous le tapis", c'est un bug, qui doit être résolu avant que l'application ne soit fournie au client final, et qui devrait -- théoriquement -- être mise en évidence pendant la période de tests précédant le déploiement de l'application (encore faut-il -- évidemment -- se tenir à une politique de test unitaires stricte )

    Le meilleur moyen pour se prémunir de ce genre de problème nous est fourni par une fonctionnalité tout droit issue du C (l'une des rares fonctionnalités propres au C dont je conseille l'usage et l'abus) : les assertions :

    Dans la fonction qui s'occupe de la division, tu peux placer une assertion selon laquelle le diviseur ne peut pas être égal à 0. Si, pour une raison ou une autre, le développeur laisse passer un diviseur égal à 0, cela plantera en période de tests. Grâce aux débuggeur, le développeur pouvoir en retrouver l'origine assez facilement, et donc, corriger le problème.

    L'avantage, c'est que, vu que le problème aura été résolu (le code corrigé), cette vérification ne sera plus nécessaire dans l'application déployée. C'est pour cela que les assert du C seront remplacé par une "noop" (aucune instruction) quand l'application sera compilée en mode "release"
    A méditer: La solution la plus simple est toujours la moins compliquée
    Ce qui se conçoit bien s'énonce clairement, et les mots pour le dire vous viennent aisément. Nicolas Boileau
    Compiler Gcc sous windows avec MinGW
    Coder efficacement en C++ : dans les bacs le 17 février 2014
    mon tout nouveau blog

  7. #7
    Membre expert
    Avatar de alassanediakite
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2006
    Messages
    1 599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Mali

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2006
    Messages : 1 599
    Points : 3 590
    Points
    3 590
    Billets dans le blog
    8
    Par défaut
    Salut
    Merci koala01, ton respect me soulage. Franchement j'avais eu le dégout de dev.com.
    Pour ce qui est de la gestion des imprévus (exception). Dans un développement réel on utilise habituellement des composants d’autrui (exemple un driver odbc ou jdbc...). Pour vous dire qu'on n'est pas maitre de tout ce qui compose notre produit. S'il faut alors laisser mourir votre application à chaque nouvelle exception non gérée je pense que le client changera vite de produit.
    Je constate que la division par zéro plante codeblock et fait dire "exception non gérée" par VS 2010.
    Je continu ma recherche.
    @+
    Le monde est trop bien programmé pour être l’œuvre du hasard…
    Mon produit pour la gestion d'école: www.logicoles.com

  8. #8
    Rédacteur/Modérateur


    Homme Profil pro
    Network game programmer
    Inscrit en
    Juin 2010
    Messages
    7 115
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : Canada

    Informations professionnelles :
    Activité : Network game programmer

    Informations forums :
    Inscription : Juin 2010
    Messages : 7 115
    Points : 32 967
    Points
    32 967
    Billets dans le blog
    4
    Par défaut
    Je pensais faire des développements réels, mais peut-être me trompe-je depuis toutes ces années

    Explique-nous comment tu peux gérer une exception non prévue ? Comment tu traites une exception non gérée ?
    Par définition, une exception non prévue survient n'importe quand et n'importe où et nous n'avons aucune information à son sujet. Partant de là, quel traitement espères-tu donc réaliser en dehors d'une réinitialisation complète de l'appli/machine ?
    Pensez à consulter la FAQ ou les cours et tutoriels de la section C++.
    Un peu de programmation réseau ?
    Aucune aide via MP ne sera dispensée. Merci d'utiliser les forums prévus à cet effet.

  9. #9
    Expert éminent sénior
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2005
    Messages
    5 074
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Val de Marne (Île de France)

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

    Informations forums :
    Inscription : Février 2005
    Messages : 5 074
    Points : 12 120
    Points
    12 120
    Par défaut
    Merci koala01, ton respect me soulage. Franchement j'avais eu le dégout de dev.com.
    Heu, mince.
    J'ai franchement déjà été largement plus cassant avec d'autres qu'avec toi.

    Dans un développement réel on utilise habituellement des composants d’autrui (exemple un driver odbc ou jdbc...). Pour vous dire qu'on n'est pas maitre de tout ce qui compose notre produit. S'il faut alors laisser mourir votre application à chaque nouvelle exception non gérée je pense que le client changera vite de produit.
    Le client va vite partir aussi quand l'application va l'accabler de message d'erreurs cryptiques ou freezer l'interface par des "traitements" d'erreurs foireux ou qui rempli le disque dur de log inexploitable.
    Le tout en maitrisant absolument pas ce qui passe, potentiellement détruisant toutes les données, ou pire, les vérolant.
    Un message d'erreur de Windows indiquant que le problème a été remonté au développeur (utilisation de WIR) et qu'il fera son maximum pour le régler dans les plus brefs délais est bien plus rassérénant.

    Si vous utilisez des composants aussi installables et mal finis, je vous conseille de faire du "surrogate" (hébergement de Dll dans un processus dédié et communication IPC entre l'application et le processus hôte) pour que leur boulettes ne vous plombe pas votre application.
    Les Driver ODBC utilisent déjà cette techniques dans la plupart des cas, où seule la partie supérieur de la couche Middleware est injectée dans l'espace de l'exécutable.
    Mais bon, des composants aussi mal foutus, ça reste pas longtemps sur le marché.

    Le but, c'est de détecter les problèmes lors des tests, pas en production, donc, on ne catche pas, sinon, on prend des années pour fiabiliser une application pour rien.

    Je constate que la division par zéro plante codeblock et fait dire "exception non gérée" par VS 2010.
    Les IDE/débuggeur, c'est un peu particulier, car ils font plus ou moins déjà du "surrogate" car ils lancent le programme à déboguer en lui attachant le débogueur.
    Le programme à déboguer est un espèce de "surrogate" du débogueur.
    Vos constatations, c'est quoi ? Le comportement de debuggee, du débuggeur, de l'IDE ???

    Je continu ma recherche.
    @+
    Vous cherchez quoi ?
    Le sujet de StackOverflow fait déjà largement le tour de la question.

    Si vous voulez pas vous prendre la tête, vous n'avez qu'à changer les options de compilation qui vont bien et catcher l'int (et pas l'exception) qui est lancé.
    Mais, franchement, bottez-vous les fesses à faire correctement les choses : validation des entrées utilisateur et des paramètres en entré des fonctions.

  10. #10
    Expert éminent sénior
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 614
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 614
    Points : 30 626
    Points
    30 626
    Par défaut
    Il faut comprendre que les exceptions devraient être réservées aux situations dont on sait qu'elles peuvent survenir, tout en espérant qu'elles ne surviennent jamais mais dont la loi de l'emmerdement maximum nous dit que, pas de bol, si elles peuvent survenir, elles surviendront forcément, et de préférence au pire moment qui soit.

    Les exemples classiques de ce genre de situation sont (de manière non exhaustive):
    • l'utilisateur qui supprime ou qui modifie un fichier ou un élément dans la base de données sans s'être assuré de maintenir la cohérence des données
    • le serveur distant basé à Singapour ou à Orlando qui plante pour une raison inconnue
    • une dépendance (non fournie par le programme) inexistante sur le système
    • une connexion internet qui plante juste au moment où l'on veut se connecter à un serveur distant
    • un périphérique quelconque inaccessible pour une raison ou une autre lorsqu'on veut l'utiliser
    • une réponse négative de la part du seveur auquel on a envoyé une requète
    • ...

    A priori, la fonction qui rencontre ce genre de problème n'a absolument aucune autorité pour essayer de le résoudre. Mais, comme elle est dans l'incapacité de continuer le traitement qu'elle est occupée à faire, vu qu'elle ne peut disposer des données dont elle a besoin, la meilleure chose à faire est encore... de sortir de ce traitement qui ne mènera à rien.

    Par la suite, il y a deux solutions:
    • soit l'une des fonctions qui a mené à l'appel de cette fonction est en mesure de résoudre le problème (en essayant de contacter le serveur "plus tard", ou en essayant de récupérer une "sauvegarde" des informations), et "on est sauvé": le processus peut reprendre, et la fonction qui a rencontré le problème ne devrait plus le rencontrer.
    • soit, on n'arrive pas à corriger le problème, et, comme nous ne pourrons de toutes manières pas avoir les données dont on a besoin, on n'a pas d'autre choix que de ... "laisser mourir" l'application de sa "belle mort".


    L'idée n'est donc pas de ne pas essayer de résoudre les problèmes, mais d'essayer de le faire "quelque part" où ... nous serons en mesure (et où il fera sens) de le faire
    A méditer: La solution la plus simple est toujours la moins compliquée
    Ce qui se conçoit bien s'énonce clairement, et les mots pour le dire vous viennent aisément. Nicolas Boileau
    Compiler Gcc sous windows avec MinGW
    Coder efficacement en C++ : dans les bacs le 17 février 2014
    mon tout nouveau blog

  11. #11
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Autre chose, il n'est pas "safe" de lancer et attraper des exceptions de, vers et même à travers une DLL ne venant pas du même compilo. Si une DLL compilée sous MinGW (gcc) appelle une DLL Win32 qui crashe, il y a des chances que les clauses catch et les destructeurs de la DLL MinGW ne soit pas exécutés (d'ailleurs même sous Visual, selon les paramètres de gestion des exceptions spécifiés au compilateur, ça peut ne pas marcher).

    When you transfer control across stack frames, all the frames in between need to be in on the joke.

    bacelar, est-il à la portée de tous d'utiliser Windows Error Reporting? Combien la société Microsoft facture-t-elle aux développeurs pour leur forwarder les rapports de plantage?
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  12. #12
    Membre expert
    Avatar de alassanediakite
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2006
    Messages
    1 599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Mali

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2006
    Messages : 1 599
    Points : 3 590
    Points
    3 590
    Billets dans le blog
    8
    Par défaut
    Salut
    koala01, je ne suis pas contre le fait qu'il faut laisser mourir l'appli. Mais pourquoi d'autres s'opposent farouchement à une deuxième option? c'est à dire signaler un problème inconnu et laisser l'appli tourner.
    Prenons le cas d'un guichet avec un appli répondant à plusieurs services pour le client.
    Une erreur inconnue survient pour un service pour un client. Faut-il ...
    • réinitialiser l'appli avec tout le temps que cela prendra?
    • ou afficher une erreur à l’opérateur qui informera tout de suite le service informatique tout en continuant à rendre d'autres services?

    Question: est-ce ce type de débat entre linux et windows sur "l'écran bleu de windows"?
    @+
    Le monde est trop bien programmé pour être l’œuvre du hasard…
    Mon produit pour la gestion d'école: www.logicoles.com

  13. #13
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Le problème, c'est qu'après une erreur qui montre une corruption du statut de l’application, laisser celle-ci tourner risque de propager les erreurs et corrompre d'autres parties... y compris les enregistrements.

    Imagine que tu travailles sur un important document Word. Si un plug-in ajouté dans Word crashe, que préfères-tu:
    • Word crashe immédiatement avec un message d'erreur que tu ne comprends pas.
    • Word affiche un message d'erreur que tu ne comprends pas. Puis il semble continuer normalement, mais la prochaine fois que tu ouvres le document, il ne contient plus rien de lisible!
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  14. #14
    Membre expert
    Avatar de alassanediakite
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2006
    Messages
    1 599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Mali

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2006
    Messages : 1 599
    Points : 3 590
    Points
    3 590
    Billets dans le blog
    8
    Par défaut
    Salut
    Citation Envoyé par Médinoc Voir le message
    Le problème, c'est qu'après une erreur qui montre une corruption du statut de l’application, laisser celle-ci tourner risque de propager les erreurs et corrompre d'autres parties... y compris les enregistrements.
    Dans le cas que j'ai signalé, je suis "sûr" que le SGBD protégera mes données.
    Citation Envoyé par Médinoc Voir le message
    Imagine que tu travailles sur un important document Word. Si un plug-in ajouté dans Word crashe, que préfères-tu:
    • Word crashe immédiatement avec un message d'erreur que tu ne comprends pas.
    • Word affiche un message d'erreur que tu ne comprends pas. Puis il semble continuer normalement, mais la prochaine fois que tu ouvres le document, il ne contient plus rien de lisible!
    Si vous n'avez pas de sauvegarde pour un important document Word aucune excuse ne peut vous être accordée. Cf Un développeur efface par erreur trois mois de travail avec Visual Studio Code 1.15
    @+
    Le monde est trop bien programmé pour être l’œuvre du hasard…
    Mon produit pour la gestion d'école: www.logicoles.com

  15. #15
    Expert éminent sénior
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2005
    Messages
    5 074
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Val de Marne (Île de France)

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

    Informations forums :
    Inscription : Février 2005
    Messages : 5 074
    Points : 12 120
    Points
    12 120
    Par défaut
    bacelar, est-il à la portée de tous d'utiliser Windows Error Reporting? Combien la société Microsoft facture-t-elle aux développeurs pour leur forwarder les rapports de plantage?
    Pas grand-chose par rapport à un support international 24h/24 7j/7.
    Sinon, on peut bricoler l'équivalent avec un simple watchdog.

    Mais pourquoi d'autres s'opposent farouchement à une deuxième option? c'est à dire signaler un problème inconnu et laisser l'appli tourner.
    Je pense qu'on a déjà pas mal illustré le fait que c'est aller droit dans le mur.

    Une erreur inconnue survient pour un service pour un client. Faut-il ...
    réinitialiser l'appli avec tout le temps que cela prendra?
    Si vous avez fait correctement votre travail (caches, point de synchronisation, etc...), le redémarrage est rapide.

    Question: est-ce ce type de débat entre linux et windows sur "l'écran bleu de windows"?
    Le rapport ???

    Dans le cas que j'ai signalé, je suis "sûr" que le SGBD protégera mes données.
    Aucunement, votre application "boguée/plantée" a les mes pouvoirs que votre application avant le problème.

    Si vous n'avez pas de sauvegarde pour un important document Word aucune excuse ne peut vous être accordée.
    L'importance, elle est variable avec le temps.

    Vérifiez les paramètres et les entrées utilisateurs, et les moutons seront bien gardés.

  16. #16
    Expert éminent sénior
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 614
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 614
    Points : 30 626
    Points
    30 626
    Par défaut
    Citation Envoyé par alassanediakite Voir le message
    Dans le cas que j'ai signalé, je suis "sûr" que le SGBD protégera mes données.
    Et comment peux tu en être "sur"

    Si la requête d'ajout / de mise a jour est correctement formulée, il n'y a absolument aucun mécanisme qui permette à SQL de refuser l'ajout ou la modification de donnée.

    Et le pire de l'histoire, c'est que tu peux très bien te retrouver avec des données qui semblent tout à fait cohérentes, mais qui ne le sont pas...

    Et ce n'est que, peut-être plusieurs mois après l'incident, que l'on se rend compte que ces données corrompues ont propagé des informations erronées qui ont fini par véroler l'ensemble du système
    Si vous n'avez pas de sauvegarde pour un important document Word aucune excuse ne peut vous être accordée.
    Oui, mais bon, il y en a encore qui travaillent "sans filet"

    Et puis, si ce n'était que le problème d'un document...

    Mais, imagine un programme de simulation, qui doit travailler pendant 7heures 30 pour fournir un résultat complet (et cela existe) . En gros, le chercheur peut lancer deux simulations sur sa journées: une au matin, une autre au soir. Et il a tout juste le temps de modifier les paramètres, avant de devoir lancer la simulation "matinale" (autrement, il est bon pour les heures supp, histoire d'attendre la fin de la simulation).

    Une donnée corrompue (pour n'importe quelle raison) va littéralement foutre en l'air l'ensemble de la simulation, car le résultat peut sembler cohérent, mais il sera aussi farfelu que les données sur lesquelles il est basé...

    Laisser mourir le programme, si tu n'as pas les moyens de récupérer l'erreur, est toujours la meilleure chose à faire, parce que, sinon, dieu seul sait ce qui peut résulter de cette erreur
    Citation Envoyé par alassanediakite Voir le message
    Salut
    koala01, je ne suis pas contre le fait qu'il faut laisser mourir l'appli. Mais pourquoi d'autres s'opposent farouchement à une deuxième option? c'est à dire signaler un problème inconnu et laisser l'appli tourner.
    Prenons le cas d'un guichet avec un appli répondant à plusieurs services pour le client.
    Une erreur inconnue survient pour un service pour un client. Faut-il ...
    • réinitialiser l'appli avec tout le temps que cela prendra?
    • ou afficher une erreur à l’opérateur qui informera tout de suite le service informatique tout en continuant à rendre d'autres services?

    @+
    Si les services sont indépendants, et que tu peux te permettre de "désactiver" le service qui pose problème, fait le... Mais, ton appli tournera "sur trois pattes", tu ne crois pas

    Maintenant, si -- comme c'est souvent le cas -- les différents services sont interconnectés, et que le service qui pose problème empêche (du seul fait du problème posé) les autres services de fonctionner, quel autre choix auras-tu que de dire "désolé, mais le service <machin> est indisponible, et ca m'empêche de faire quoi que ce soit d'autre"...

    En plus, imagine l'opérateur qui doit dire "ah, désolé, mais ce service là ne fonctionne justement pas"... C'est lui (et non l'application ou son développeur) qui passe pour un con
    A méditer: La solution la plus simple est toujours la moins compliquée
    Ce qui se conçoit bien s'énonce clairement, et les mots pour le dire vous viennent aisément. Nicolas Boileau
    Compiler Gcc sous windows avec MinGW
    Coder efficacement en C++ : dans les bacs le 17 février 2014
    mon tout nouveau blog

  17. #17
    Membre expert
    Avatar de alassanediakite
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2006
    Messages
    1 599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Mali

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2006
    Messages : 1 599
    Points : 3 590
    Points
    3 590
    Billets dans le blog
    8
    Par défaut
    Salut
    La leçon est très bien comprise. Je tacherai dorénavant de faire le meilleur choix.
    Pour...
    Citation Envoyé par koala01 Voir le message
    En plus, imagine l'opérateur qui doit dire "ah, désolé, mais ce service là ne fonctionne justement pas"... C'est lui (et non l'application ou son développeur) qui passe pour un con
    on est fréquemment confronté à ces genres de problèmes et on a toujours compris que l'opérateur n'y est pour rien et ils ont très souvent la bonne manière pour repondre.
    Merci à vous et @+
    Le monde est trop bien programmé pour être l’œuvre du hasard…
    Mon produit pour la gestion d'école: www.logicoles.com

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

Discussions similaires

  1. Gestion des piles avec les classe
    Par souad21 dans le forum C++
    Réponses: 1
    Dernier message: 24/10/2007, 06h10
  2. Réponses: 1
    Dernier message: 29/04/2006, 18h24
  3. pb avec un classe d'exception
    Par richard038 dans le forum Langage
    Réponses: 6
    Dernier message: 18/01/2006, 10h28
  4. [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
  5. Pb avec une Classe d'exception EOleError
    Par raoulmania dans le forum Composants VCL
    Réponses: 2
    Dernier message: 27/05/2005, 12h39

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