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

MFC Discussion :

[MFC] Processus qui ne s'arrête pas quand la boîte de dialogue se ferme


Sujet :

MFC

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2015
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2015
    Messages : 42
    Points : 22
    Points
    22
    Par défaut [MFC] Processus qui ne s'arrête pas quand la boîte de dialogue se ferme
    Bonjour à tous,

    je viens de finir une boîte de dialogue MFC qui fonctionne à peu près correctement.

    Contexte : globalement, le programme écrit un fichier (.dgibi) qui est ensuite ouvert par un logiciel de calcul (Cast3M pour ceux qui connaissent). Une fois le calcul terminé, le logiciel se ferme et le programme MFC reprend la main pour se servir des résultats. Un traitement est fait sur les résultats puis le fichier (.dgibi) est réécrit, puis relancé par le logiciel etc.... jusqu'à ce qu'un des critères de convergence soit atteint.

    Problème : lorsque je quitte la boîte de dialogue, les calculs continuent toujours. Je suis obligé de fermer le processus un peu sauvagement par le gestionnaire des tâches Windows.

    Je me doute bien que l'erreur vient de moi mais je ne vois pas vraiment comment faire pour régler le problème.

    Merci d'avance

  2. #2
    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
    Est-ce une application dialog-based, avec un DoModal() dans le InitInstance()?
    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.

  3. #3
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2015
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2015
    Messages : 42
    Points : 22
    Points
    22
    Par défaut
    Oui c'est une application dialog-based.
    Non, je n'ai pas de IniInstance().
    En revanche, j'ai un DoModal() dans le OnSysCommand().

  4. #4
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2015
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2015
    Messages : 42
    Points : 22
    Points
    22
    Par défaut
    Oula, désolé. J'ai répondu complètement à côté de la plaque.

    Oui effectivement, il y a bien un DoModal() dans le InitInstance().

  5. #5
    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
    Et en attachant le débuggeur de VS à la place d'utiliser le gestionnaire des tâches, ça vous donne quoi comme code en cour d'exécution ?

  6. #6
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2015
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2015
    Messages : 42
    Points : 22
    Points
    22
    Par défaut
    Quand je me mets en mode DEBUG et que je clique sur le bouton "Quitter" de ma boîte de dialogue, ça ferme l'application mais le calcul continue toujours derrière.

    Pour que ça s'arrête, il faut que j'arrête le débogueur et là tout se ferme.

    Autrement dit, ça fait la même chose que ce que j'ai décrit dans mon premier post.

  7. #7
    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
    Quel calcul?
    Normalement dans le cas "classique" de fenêtre fermée sans quitter la boucle de messages, tout ce que le programme fait, c'est une attente passive.
    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.

  8. #8
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2015
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2015
    Messages : 42
    Points : 22
    Points
    22
    Par défaut
    Quel calcul?
    Pardon si je ne suis pas clair.

    L'application lance un exécutable qui fait des calculs sur mon fichier (.dgibi) que j'écris juste avant. Une fois le calcul terminé, l'exécutable se ferme automatiquement et mon application (boîte de dialogue) charge les résultats du calcul.

    Si je clique sur mon bouton "Quitter" pour fermer la boîte de dialogue, et bien dans le gestionnaire des tâches, il y a toujours mon application qui est ouverte et les calculs continuent. Je le sais parce que dans le gestionnaire, l'exécutable (qui fait les calculs) apparaît et disparaît successivement.

  9. #9
    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
    Hé bien il faut savoir comment exactement ton programme Dialog attend la fin du programme Calcul, et savoir ce que tu veux faire précisément quand on quitte le programme Dialog:
    • Quitter le programme Dialog complètement mais laisser le programme Calcul tourner jusqu'à la fin (l'état actuel, si j'ai bien compris)
    • Tuer le programme Calcul avant de quitter le programme Dialog
    • Tenter d'interrompre le programme Calcul proprement, et le tuer s'il ne se termine pas in X secondes


    etc.

    Le problème, c'est que tu risques de ne même pas pouvoir essayer de quitter le programme Calcul proprement, s'il s'agit d'un programme externe dont tu n'as pas les sources; dans ce cas, tu vas être obligé de tuer le processus (via TerminateProcess()).
    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.

  10. #10
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2015
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2015
    Messages : 42
    Points : 22
    Points
    22
    Par défaut
    Oui je comprends.

    Mais du coup, je ne comprends pas la chose suivante : à la base, j'avais un programme en console qui faisait EXACTEMENT la même chose et quand je cliquais sur "Fermer", la console se fermait et les calculs s'arrêtaient.

    Or j'ai l'impression que le fait de fermer la boîte de dialogue ne la ferme pas vraiment, c'est-à-dire qu'elle ne s'affiche plus, en ce sens elle est fermée, mais son exécutable est toujours présent dans le gestionnaire des tâches. D'où, à mon humble avis, le fait que les calculs continuent.

  11. #11
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2015
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2015
    Messages : 42
    Points : 22
    Points
    22
    Par défaut
    A mon humble avis, je pense que le problème vient, non pas du fait que les calculs continuent, mais plutôt du fait que la boîte de dialogue reste "active" en quelque sorte. C'est-à-dire qu'elle se ferme quand je clique sur "Quitter" mais son exécutable est toujours en train de tourner. Ce qui explique pourquoi les calculs continuent.

    Peut-être que j'ai oublié quelque chose dans le code pour fermer la boîte de dialogue :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    void CDlg::OnBnClickedCancel()
    {
         CDialogEx::OnCancel();
    }

  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
    Citation Envoyé par js_naka Voir le message
    Mais du coup, je ne comprends pas la chose suivante : à la base, j'avais un programme en console qui faisait EXACTEMENT la même chose et quand je cliquais sur "Fermer", la console se fermait et les calculs s'arrêtaient.
    Fermer une Console tue tous les processus Console qu'elle contient, plus ou moins proprement (voir fonction CreateConsoleCtrlHandler()), et selon les paramètres un processus fils est créé (ou non) dans la même console...

    Cela explique les différences entre les versions console et non-console de ton programme appelant.
    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
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2015
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2015
    Messages : 42
    Points : 22
    Points
    22
    Par défaut
    Désolé pour le retard mais je viens de résoudre mon problème.

    Bon, c'est un peu en mode Mr Bricolage mais bon ça fonctionne.

    J'ai défini un booléen dans ma procédure qui lance les calculs, et dès que je clique sur le bouton "Quitter", le booléen change d'état.

    Cela provoque la sortie des boucles de calculs et enfin je ferme ma boîte de dialogue. Du coup, tout se ferme correctement.

    Merci à vous en tout cas pour votre aide.

  14. #14
    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
    Moi, je ne trouve pas que cela soit du bricolage, mais avec un Event ça serait un peu plus carré.

  15. #15
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2015
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2015
    Messages : 42
    Points : 22
    Points
    22
    Par défaut
    Sans doute mais je ne connais pas du tout Event. Et le peu que je viens de voir à propos de ça sur Internet me fait un peu peur.

  16. #16
    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
    Fais gaffe là, il y a pas mal de choses qui s'appellent Event.

    Ici, on parle de ceux qui sont des objets du kernel, créés par CreateEvent(), et que MFC wrappe dans la classe CEvent. C'est un peu comme un booléen inter-processus et garanti volatile (ce qui veut dire que l'optimiseur ne va pas venir faire n'importe quoi quand tu le consultes à chaque itération d'une boucle).
    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.

  17. #17
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2015
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2015
    Messages : 42
    Points : 22
    Points
    22
    Par défaut
    Ok, je vais y jeter un coup d’œil quand même mais je ne suis pas certain d'avoir la volonté de le faire.

    Je vais perdre beaucoup de temps à essayer de l'implémenter pour finalement le même résultat.

    J'ai entendu des spécialistes dire qu'il est déconseillé de programmer en fonction de ses compétences et qu'il faut programmer en fonction du langage utilisé mais là, je vais faire une pause. Je reviendrai dessus plus tard.

    En tout cas, merci à vous pour votre aide.

    Forum toujours agréable avec des personnes compétentes qui réagissent vite. Que demande le peuple.

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 08/03/2007, 21h00
  2. [SQL] une requête qui ne s'arrête pas ou si loin
    Par lodan dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 12/10/2006, 14h36
  3. Lancer une tâche planifiée qui ne s'arrête pas
    Par bart64 dans le forum Windows Serveur
    Réponses: 12
    Dernier message: 02/10/2006, 19h33
  4. [FLASH MX2004] Clip qui ne s'arrête pas
    Par romain starck dans le forum ActionScript 1 & ActionScript 2
    Réponses: 8
    Dernier message: 10/05/2006, 19h43
  5. [VBA-E]une boucle qui ne s'arrète pas
    Par vivelesgnous dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 15/02/2006, 18h05

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