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 :

Exception passant à travers les catch


Sujet :

C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Inactif  


    Homme Profil pro
    Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Inscrit en
    Décembre 2011
    Messages
    9 026
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Secteur : Enseignement

    Informations forums :
    Inscription : Décembre 2011
    Messages : 9 026
    Par défaut Exception passant à travers les catch
    Bonjour,

    Je teste actuellement une application sous Windows et j'ai un petit problème sur ce bout de code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    try {
              std::cerr << "debut" << std::endl;
              std::cerr.flush();
              boost::filesystem3::copy( path, boost::filesystem3::path("temp_PDF") / path.filename()  );
              std::cerr << "fin" << std::endl;
              std::cerr.flush();
    } catch ( boost::filesystem3::filesystem_error e )
    {
              std::cerr << "except" << std::endl;
             std::cerr.flush();
    } catch ( ... )
    {
             std::cerr << "erreur 1" << std::endl;
             std::cerr.flush();
    }
    catch(...) étant censé, il me semble, pouvoir rattraper toutes les exceptions.
    Ce que je n'arrive pas à m'expliquer, c'est que la ligne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    boost::filesystem3::copy( path, boost::filesystem3::path("temp_PDF") / path.filename()  );
    lance une exception qui n'est pas attrapée...

    Voici ce que j'ai à l'écran :
    debut
    terminate after throwing an instance of 'boost::filesystem::filesystem_error'
    what() : [...]

    This application has requested the Runtime to terminate it in a unusual way.
    Please contact the application's support team for more information.

    Je ne sais pas si c'est lié mais je ne peux pas lancer mon application deux fois de suite dans la même console DOS ( l'application retourne directement sans rien faire).
    J'ai aussi, quand l'exception n'est pas lancée, un system() qui n'exécute pas la commande passée en argument .

    Est-ce que vous auriez une idée ?

  2. #2
    Membre Expert
    Avatar de Klaim
    Homme Profil pro
    Développeur de jeux vidéo
    Inscrit en
    Août 2004
    Messages
    1 717
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur de jeux vidéo
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2004
    Messages : 1 717
    Par défaut
    Pour l'instant je note juste que tu catch l'exception par copie et je me demande si c'est pas un probleme.

    Sinon, je suis pas specialiste mais il ne se pourait pas qu'il y ait un appel direct a terminate() a cause d'une exception qui se lance dans un catch?

  3. #3
    Expert éminent

    Femme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    5 202
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Juin 2007
    Messages : 5 202
    Par défaut
    par ailleurs, pourquoi flusher après un <<std::endl.

    std::endl fait le flush.

  4. #4
    Inactif  


    Homme Profil pro
    Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Inscrit en
    Décembre 2011
    Messages
    9 026
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Secteur : Enseignement

    Informations forums :
    Inscription : Décembre 2011
    Messages : 9 026
    Par défaut
    Citation Envoyé par leternel Voir le message
    par ailleurs, pourquoi flusher après un <<std::endl.

    std::endl fait le flush.
    Malheureusement pas toujours

    Quand on exécute un programme dans la console de QtCreator, le std::endl ne flush pas toujours.
    J'ai donc pris l'habitude de mettre un std::cerr.flush() pour m'éviter toutes mauvaises surprises.

    Pour l'instant je note juste que tu catch l'exception par copie et je me demande si c'est pas un probleme.
    J'attrape le même type d'exceptions sans problème sous Linux, donc je ne pense pas que ce soit ça.
    De plus, même si l'exception n'est pas rattrapée par le premier catch, elle devrait obligatoirement l'être par le second non?


    Sinon, je suis pas specialiste mais il ne se pourait pas qu'il y ait un appel direct a terminate() a cause d'une exception qui se lance dans un catch?
    Il n'y a pas d'exceptions qui se lancent dans un catch ici il me semble non?
    Si la copie est interdite, il devrait théoriquement directement passer au catch suivant.

    J'essaye de passer par référence pour voir ce que cela donne

    EDIT : même en passant par référence constante au lieu de la copie, rien ne change.

  5. #5
    Inactif  


    Homme Profil pro
    Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Inscrit en
    Décembre 2011
    Messages
    9 026
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Secteur : Enseignement

    Informations forums :
    Inscription : Décembre 2011
    Messages : 9 026
    Par défaut
    J'ai oublié de le préciser, mais sous Windows, j'ai fait un :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    #define filesystem3 filesystem
    Car sous Windows, filesystem3 n'existe pas.

  6. #6
    Membre Expert
    Homme Profil pro
    Inscrit en
    Décembre 2010
    Messages
    734
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 734
    Par défaut
    Tu linkes en statique ou dynamique? Ca me fait penser à des problèmes d'exceptions qui franchissent des DLL boundaries...

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

Discussions similaires

  1. Réponses: 7
    Dernier message: 14/11/2008, 11h49
  2. Pb : Exception / déroutements / try, throw, catch
    Par Bapt_from_Reims dans le forum C++
    Réponses: 5
    Dernier message: 18/03/2005, 17h55
  3. [typedef] protection à travers les espaces de noms
    Par PINGOUIN_GEANT dans le forum C++
    Réponses: 7
    Dernier message: 02/02/2005, 20h21
  4. [Exceptions] Pb avec les exceptions
    Par joquetino dans le forum Langage
    Réponses: 11
    Dernier message: 22/09/2004, 17h08
  5. Copies de flots en passant par les itérateurs
    Par Christophe Brun dans le forum C++
    Réponses: 7
    Dernier message: 02/07/2003, 11h41

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