|
Publicité ' | |||||||||||||||||||||||
|
|
#1 |
|
Invité de passage
![]() Nicolas Étudiant Inscription : décembre 2012 Messages : 2 ![]() |
Bonjour,
je suis débutant en c++ et j'ai du mal avec les exeptions. Je comprend le principe par contre je ne sais pas du tout comment l'intégrer à mon proramme de recherche dichotomique. Ici j'en ai besoins pour gérer une entrée incohérente : une borne de recherche supérieur à la taille du tableau d'entier ou inférieur à 0. J'espere que quelqu'un pourra m'éclairer un peu |
|
|
00
|
|
|
#2 | ||
|
Membre éprouvé
![]() Étudiant Inscription : février 2012 Messages : 206 ![]() |
Bonjour
Lorsque tu throw ton exception dans la fonction rechercheDichotomique, il faut en construire une. Le constructeur de std::out_of_range prend une chaîne de caractère. http://www.cplusplus.com/reference/s.../out_of_range/ Voici un exemple (modifié) issu de la FAQ http://cpp.developpez.com/faq/cpp/?page=exceptions Code :
Il est important de préciser que ton code est à vocation pédagogique ou dans le cadre scolaire pour ne pas avoir de messages du genre «utilise std::vector et std::sort» Il faut aussi que tu détailles mieux l'erreur rencontrée et qu'elle est la partie qui te pose réellement problème. [Tu peux aussi utiliser la balise [CODE] pour insérer du code dans le message. Je trouve ça plus pratique que le fichier.] |
||
|
|
00
|
|
|
#3 | ||||
|
Invité de passage
![]() Nicolas Étudiant Inscription : décembre 2012 Messages : 2 ![]() |
Merci pour les conseils, les forum sont nouveaux pour moi.
J'ai résolu mon probleme, en faite je n'ai pas encore assez avancé dans mes cours pour comprendre les classe d'exeptions ( le code concerne un TP bonus ). Ducoup j'ai réussi de cette manière : Programme principal: Code :
Code :
|
||||
|
|
00
|
|
|
#4 |
|
Membre éprouvé
![]() Étudiant Inscription : février 2012 Messages : 206 ![]() |
(Bienvenue à toi alors
Oui, cela est correct (dans le cadre scolaire) (syntaxiquement). À toi de faire des tests/jeux d'essais pour voir si l'exception est bien levé avec des n invalides et que le calcul est bien fait dans les cas valides. Pour aller plus loin: Tu peux remplacer ton int par un std::out_of_range. Sauf qu'au lieu de throw n tu throw std::out_of_range("Description de l'exception") et tu catch un std::out_of_range & au lieu du int. (Tu peux aussi utiliser un std::string si tu les as vu et que std::out_of_range te perturbe.) Utilise plutôt std::cout << "texte" << std::endl; plutôt que "\n"; Si le problème est résolu, il faut le noter résolu |
|
|
00
|
|
|
#5 | ||
|
Expert Confirmé
![]() Pierre Ingénieur développement logiciels Inscription : juin 2007 Messages : 1 185 ![]() |
Bonjour,
j'en profite pour indiquer que std::out_of_range est définie (avec d'autres exceptions) dans <stdexcept> au final, la capture d'une exception devrait se faire via une référence constante, pour ne pas la copier, et ne pas perdre le polymorphisme (parce que certaines exception hérite d'une autre) le code devient alors: Code :
__________________
Mes principes de bases du codeur qui veut pouvoir dormir:
|
||
|
00
|
|
|
#6 | |||||
|
Membre éprouvé
![]() Étudiant Inscription : février 2012 Messages : 206 ![]() |
Citation:
Lorsque j'aurais plus de temps je voulais voir si on peut expliquer ce code proprement et le mettre dans la FAQ (si ce n'est pas déjà fait) Code :
Code :
Pour avoir le comportement voulu, on doit surcharger les fonctions avec le type voulu. (On peut utiliser la programmation générique avec les templates.) Bref, je ferais les vérifications nécessaires et posterais un petit message à ce sujet si besoin. |
|||||
|
|
00
|
|
|
#7 |
|
Expert Confirmé
![]() Pierre Ingénieur développement logiciels Inscription : juin 2007 Messages : 1 185 ![]() |
En effet, bonne question.
Ta version non template est équivalente à l'appel explicite de la template throw_except<std::exception>(std::logic_error("Description of exception"));Mais pourquoi, je n'en sais rien.
__________________
Mes principes de bases du codeur qui veut pouvoir dormir:
|
|
00
|
|
|
#8 |
![]() ![]() Germino LegrandDéveloppeur de jeux vidéo Inscription : octobre 2010 Messages : 369 ![]() |
@Ehonn: en fait il n'y a aucun intérêt à ce code, passer une exception en paramètre d'une fonction pour qu'elle la lance n'a tout simplement aucun sens... On perd la simplicité du throw (sans parler de la perte de polymorphisme que je trouve intéressante).
Donc je doute de la possibilité de retrouver ce genre de code dans un projet... Par contre je m'étonne que personne ne rajoute catch(...) après le dernier bloc catch d'un try... alors que ça fournit un système très simple et puissant de gestion des erreurs... et une belle exploitation du RAII
__________________
|
|
00
|
|
|
#9 |
|
Expert Confirmé
![]() Pierre Ingénieur développement logiciels Inscription : juin 2007 Messages : 1 185 ![]() |
catch(...) n'est pas l'application du RAII, c'est l'attrapage de toute exception.
RAII repose sur l'exploitation du contraire. En effet, le principe se résumerait à "la ressource est manipulable aussi longtemps que la variable existe, ni plus ni moins." toute sortie de scope (paire d'accolade, normalement) provoque la destruction des variables locales qu'il contient. Les constructeurs lance des exceptions pour empecher l'utilisation de ressource qui n'ont pas pu être acquises, et les destructeurs libère la dite ressource. catch(…) bloque la remontée des exceptions. PS: pour les plus débutant, je rappelle que n'importe quoi peut-être levé via throw. Le compilateur ne vous empechera d'utiliser throw printf; bien que le type de printf soit un truc aussi barbare que (int)(*)(const char*, …). Par contre, c'est du suicide professionnel.
__________________
Mes principes de bases du codeur qui veut pouvoir dormir:
|
|
00
|
|
|
#10 |
![]() ![]() Germino LegrandDéveloppeur de jeux vidéo Inscription : octobre 2010 Messages : 369 ![]() |
Oups, dit une bêtise, seulement dans les fonctions d'entrée (main, fonction threadée, etc.). Pour moi une exception ne doit pas faire planter le programme (faut utiliser assert pour ça). Elle doit plutôt remettre le programme dans un état stable. Donc un catch(...) dans le main peut aider à signaler l'erreur à l'utilisateur (ouverture d'une fenêtre pop-up, etc.). Oubliez ce que j'ai dit sur le RAII, rien à voir
(moi ce que je mets dans un catch(...) ailleurs que dans ces fonctions là se résume souvent à un throw)
__________________
|
|
00
|
|
|
#11 |
![]() ![]() Florian BlanchetEtudiant en Optique Inscription : août 2004 Messages : 1 060 ![]() |
Comment tu arrives à remettre le programme dans un état valide avec un catch(...) ?
En général la présence d'un catch(...) masque le fait que le développeur ne sait pas comment remettre le programme dans un état valide. Si le programme ne peut pas être remis dans un état valide, pourquoi ne pas le laisser planter ? Sans catch(...) il pourra y avoir un core-dump qui donnera toutes les informations voulues aux développeur pour comprendre l'état du programme .
__________________
"We can solve any problem by introducing an extra level of indirection" Butler Lampson "N'importe quel problème peut être résolu en introduisant un niveau d'indirection supplémentaire" Butler Lampson (traduction libre) |
|
|
00
|
|
|
#12 | ||
|
Membre éprouvé
![]() Étudiant Inscription : février 2012 Messages : 206 ![]() |
Citation:
assert qui vient de la bibliothèque C, est une macro et ne permet pas de lancer d'exception, elle fait un abort (je ne pense pas que la mémoire et les ressources soit correctement libérées par le programme lui même mais peu importe). Même pour un assert, il est légitime de vouloir throw une exception. Il est aussi légitime de vouloir activer ces assertions seulement si NDEBUG n'est pas défini par exemple. On peut aussi afficher un message dans un certain style (en rouge par exemple). Pour éviter de copier-coller ces lignes, on peut factoriser ce code (pour le NDEBUG c'est une mauvaise idée car un appel de fonction vide peut quand même tuer les performances avec g++ 4.7 en -O3 !). Citation:
|
||
|
|
00
|
Copyright © 2000-2013 - www.developpez.com