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

Threads & Processus C++ Discussion :

[MT] thread et plantage


Sujet :

Threads & Processus C++

  1. #1
    yan
    yan est déconnecté
    Rédacteur
    Avatar de yan
    Homme Profil pro
    Ingénieur expert
    Inscrit en
    Mars 2004
    Messages
    10 033
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur expert
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2004
    Messages : 10 033
    Points : 13 968
    Points
    13 968
    Par défaut [MT] thread et plantage
    Bonjour,
    j'ai un programme qui exploite une dll.
    Dans cette dll il y as une création d'un thread pour des traitement spécifique.
    Malheuresement, lorsque le programme plante, ce thread plante aussi et ne va donc pas terminer son traitement.

    J'aimerai savoir si il était possible (et comment faire ) pour que soit :
    - ce thread termine malgré le crash.
    - un morceau de code est appelé pour terminer correctement le traitement.

    merci

  2. #2
    yan
    yan est déconnecté
    Rédacteur
    Avatar de yan
    Homme Profil pro
    Ingénieur expert
    Inscrit en
    Mars 2004
    Messages
    10 033
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur expert
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2004
    Messages : 10 033
    Points : 13 968
    Points
    13 968
    Par défaut
    ah oui. c'est des thread windows

  3. #3
    Membre averti Avatar de Kujara
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    262
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Décembre 2006
    Messages : 262
    Points : 358
    Points
    358
    Par défaut
    Pour autant que je sache, c'est pas possible.

    Sous windows, quand ça plante, ça plante >.<

    Par contre, si c'est une exception, catch la, fait ton cleanup, et quitte.

  4. #4
    Rédacteur
    Avatar de Laurent Gomila
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2003
    Messages
    10 651
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2003
    Messages : 10 651
    Points : 15 920
    Points
    15 920
    Par défaut
    Un thread est tué si son processus père est tué, donc la solution serait de créer non pas un nouveau thread, mais un nouveau processus (faire deux programmes séparés, en gros).

    Mais bon, si tu as un crash, c'est ça qu'il faut corriger en priorité.

  5. #5
    yan
    yan est déconnecté
    Rédacteur
    Avatar de yan
    Homme Profil pro
    Ingénieur expert
    Inscrit en
    Mars 2004
    Messages
    10 033
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur expert
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2004
    Messages : 10 033
    Points : 13 968
    Points
    13 968
    Par défaut
    Citation Envoyé par Laurent Gomila Voir le message
    Un thread est tué si son processus père est tué, donc la solution serait de créer non pas un nouveau thread, mais un nouveau processus (faire deux programmes séparés, en gros).

    Mais bon, si tu as un crash, c'est ça qu'il faut corriger en priorité.
    Normalement y as pas de raison que ce crash. Puis je ne touche pas à cette appli. Mais bon on sait jamais. Comme c'est pour un produit, je me demandé si il y avait un moyen de blinder ça.
    Tans pis...
    merci

  6. #6
    yan
    yan est déconnecté
    Rédacteur
    Avatar de yan
    Homme Profil pro
    Ingénieur expert
    Inscrit en
    Mars 2004
    Messages
    10 033
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur expert
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2004
    Messages : 10 033
    Points : 13 968
    Points
    13 968
    Par défaut
    Citation Envoyé par Kujara Voir le message
    Pour autant que je sache, c'est pas possible.

    Sous windows, quand ça plante, ça plante >.<

    Par contre, si c'est une exception, catch la, fait ton cleanup, et quitte.
    Question bête.
    L'appli est en VBA ().
    Si elle crash.
    Elle lance une exception? Dans ce cas, je peut la récupérer et la traiter dans la DLL??

  7. #7
    Rédacteur
    Avatar de Laurent Gomila
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2003
    Messages
    10 651
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2003
    Messages : 10 651
    Points : 15 920
    Points
    15 920
    Par défaut
    Pas d'exception en VBA, en de toute façon les exceptions ne sont pas censées passer entre une DLL et un processus l'utilisant.

    Mais à mon avis la DLL est déchargée proprement lorsque l'appli crash, donc tu pourrais intercepter le message correspondant dans ton DllMain et terminer ta DLL proprement.

  8. #8
    Expert éminent sénior
    Avatar de Mat.M
    Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2006
    Messages
    8 361
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2006
    Messages : 8 361
    Points : 20 381
    Points
    20 381
    Par défaut
    Citation Envoyé par Mongaulois Voir le message
    Bonjour,
    j'ai un programme qui exploite une dll.
    C'est une dll COM ou dll "classique" ?
    Il est vivement recommandé de faire une dll ATL-COM plutot que "classique" .
    Les dll Automation supportent mieux l'interfaçage avec les autres programmes ( fait en VB,VBA etc..) en plus tu peux faire des "fires" qui communiquent avec le programme parent.
    Si le programme en VBA plante c'est qu'il n'est pas synchro avec la dll.
    En principe un programme VBA ne devrait pas planter parce que les runtimes VB gèrent les exceptions systèmes

  9. #9
    yan
    yan est déconnecté
    Rédacteur
    Avatar de yan
    Homme Profil pro
    Ingénieur expert
    Inscrit en
    Mars 2004
    Messages
    10 033
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur expert
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2004
    Messages : 10 033
    Points : 13 968
    Points
    13 968
    Par défaut
    Citation Envoyé par Mat.M Voir le message
    C'est une dll COM ou dll "classique" ?
    Il est vivement recommandé de faire une dll ATL-COM plutot que "classique" .
    Les dll Automation supportent mieux l'interfaçage avec les autres programmes ( fait en VB,VBA etc..) en plus tu peux faire des "fires" qui communiquent avec le programme parent.
    Si le programme en VBA plante c'est qu'il n'est pas synchro avec la dll.
    En principe un programme VBA ne devrait pas planter parce que les runtimes VB gèrent les exceptions systèmes
    c'est plus compliqué .
    En faite c'est un driver twain. Un driver twain est un dll.
    L'applie utilise eztwain comme interface twain.
    C'est une sécurité au driver que je veut ajouter.

  10. #10
    yan
    yan est déconnecté
    Rédacteur
    Avatar de yan
    Homme Profil pro
    Ingénieur expert
    Inscrit en
    Mars 2004
    Messages
    10 033
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur expert
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2004
    Messages : 10 033
    Points : 13 968
    Points
    13 968
    Par défaut
    Citation Envoyé par Mat.M Voir le message
    En principe un programme VBA ne devrait pas planter parce que les runtimes VB gèrent les exceptions systèmes
    Euh... En fait je kill l'appli a la main pendant le traitement pour simuler un plantage. Je ne comprend pas pourquoi une appli VBA ne peut pas planter?
    Si elle ne plante pas c'est beaucoup plus simple pour moi , mais bon....

  11. #11
    yan
    yan est déconnecté
    Rédacteur
    Avatar de yan
    Homme Profil pro
    Ingénieur expert
    Inscrit en
    Mars 2004
    Messages
    10 033
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur expert
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2004
    Messages : 10 033
    Points : 13 968
    Points
    13 968
    Par défaut
    Citation Envoyé par Laurent Gomila Voir le message
    Mais à mon avis la DLL est déchargée proprement lorsque l'appli crash, donc tu pourrais intercepter le message correspondant dans ton DllMain et terminer ta DLL proprement.
    J'ai rien trouvé... Le seul message ,que j'ai trouvé DLL_THREAD_DETACH, qui correspond au déchargement d'une DLL n'est pas emit lors d'un crash

  12. #12
    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
    Essaie aussi DLL_PROCESS_DETACH, puisque c'est tout le process qui tombe.
    Mais je doute fort que les DLLs soient notifiées lors d'un crash. Elles ne le sont pas dans un TerminateProcess(), en tout cas...
    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.

  13. #13
    yan
    yan est déconnecté
    Rédacteur
    Avatar de yan
    Homme Profil pro
    Ingénieur expert
    Inscrit en
    Mars 2004
    Messages
    10 033
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur expert
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2004
    Messages : 10 033
    Points : 13 968
    Points
    13 968
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    Essaie aussi DLL_PROCESS_DETACH, puisque c'est tout le process qui tombe.
    Mais je doute fort que les DLLs soient notifiées lors d'un crash. Elles ne le sont pas dans un TerminateProcess(), en tout cas...
    a zut je me suis trompé... c'etait cela que je voulais mettre. Mais c'est pareil. los d'un crash j'ai rien.. Remarque,
    killer une application == simulation d'un plantage?

  14. #14
    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
    Je dirais plutôt que gravité d'un plantage == tuer l'application.
    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.

  15. #15
    yan
    yan est déconnecté
    Rédacteur
    Avatar de yan
    Homme Profil pro
    Ingénieur expert
    Inscrit en
    Mars 2004
    Messages
    10 033
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur expert
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2004
    Messages : 10 033
    Points : 13 968
    Points
    13 968
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    Je dirais plutôt que gravité d'un plantage == tuer l'application.
    Je peut donc bien simuler un plantage et killant mon appli

  16. #16
    Expert éminent sénior
    Avatar de Mat.M
    Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2006
    Messages
    8 361
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2006
    Messages : 8 361
    Points : 20 381
    Points
    20 381
    Par défaut
    Citation Envoyé par Mongaulois Voir le message
    c'est plus compliqué .
    En faite c'est un driver twain. Un driver twain est un dll.
    L'applie utilise eztwain comme interface twain.
    C'est une sécurité au driver que je veut ajouter.
    Et il n'y pas des API Windows qui proposent de piloter une interface TWAIN ?

  17. #17
    yan
    yan est déconnecté
    Rédacteur
    Avatar de yan
    Homme Profil pro
    Ingénieur expert
    Inscrit en
    Mars 2004
    Messages
    10 033
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur expert
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2004
    Messages : 10 033
    Points : 13 968
    Points
    13 968
    Par défaut
    Citation Envoyé par Mat.M Voir le message
    Et il n'y pas des API Windows qui proposent de piloter une interface TWAIN ?
    ??
    Pas windows (enfin oui sous vista). Mais twain est nativement dans windows maintenant.
    Je ne comprend pas t'as question. Je développe un driver twain, et je voulais savoir si il était possible d'effectuer un traitement s'il y as un crash de l'appli qui l'utilise. La réponse est non. Si ca crash, ca crash

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

Discussions similaires

  1. Plantage dans un thread fils
    Par stehga dans le forum POSIX
    Réponses: 10
    Dernier message: 15/05/2008, 18h12
  2. Plantage dans un thread fils
    Par stehga dans le forum Windows
    Réponses: 2
    Dernier message: 14/05/2008, 20h51
  3. Réponses: 2
    Dernier message: 06/03/2007, 11h07
  4. Pb de code d'erreur sur plantage thread
    Par mbianchi dans le forum Windows
    Réponses: 4
    Dernier message: 17/03/2006, 09h38
  5. Réponses: 15
    Dernier message: 07/07/2005, 11h05

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