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

Windows Discussion :

fork() pour win32


Sujet :

Windows

  1. #1
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 2
    Points : 1
    Points
    1
    Par défaut fork() pour win32
    Bonjour,

    Dans mon application portable linux/win32, mon code execute des scripts python
    via l'API C python. Or il arrive que certaines librairies python fasse planter toute l'application au déchargement des modules.
    Sous linux j'ai résolu ce problème en créant un nouveau process qui lance le code python. Pour cela j'ai utilisé fork.
    CreateProcess est l'équivalent de fork() + exec( ). Je cherche l'équivalent de fork() tout seul car je souhaite que le process execute le code que mon application assigne au fils et non pas le code d'un autre programme.
    Est-ce possible sous windows?
    Il semble que cygwin émule le fork grace à CreateProcess mais je n'ai pas trouvé dans les sources l'astuce.

    Merci

  2. #2
    Membre averti
    Avatar de joellel
    Profil pro
    Inscrit en
    Février 2003
    Messages
    234
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Février 2003
    Messages : 234
    Points : 338
    Points
    338
    Par défaut
    Citation Envoyé par Krispyro
    Bonjour,
    Je cherche l'équivalent de fork() tout seul car je souhaite que le process execute le code que mon application assigne au fils et non pas le code d'un autre programme.
    Pourquoi? Sous Windows, ça n'existe pas. Je vois 2 solutions:
    1/ tu crées un nouveau thread qui effectue ton traitement dans ce cas, tu as un seul exécutable et ton thread pourra se planter tout seul
    2/ Tu crées un autre programme exécutable, avec le code que tu voulais assigner au fils et tu le lances avec CreateProcess.

  3. #3
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 2
    Points : 1
    Points
    1
    Par défaut plouf
    Citation Envoyé par joellel
    Pourquoi? Sous Windows, ça n'existe pas. Je vois 2 solutions:
    1/ tu crées un nouveau thread qui effectue ton traitement dans ce cas, tu as un seul exécutable et ton thread pourra se planter tout seul
    2/ Tu crées un autre programme exécutable, avec le code que tu voulais assigner au fils et tu le lances avec CreateProcess.
    Bon j'ai essayé avec CreateThread, _beginthread et pthread_create. Dans tous les cas le code du thread crée fait planter toute l'application
    Ca fait plaisir de voir un meme comportement avec plusieur implémentations de thread sur plusieurs archi différentes. On peut donc en déduire que quand un thread plante, l'application qui l'a crée suit le mouvement.
    Pour info, l'éxecution du python via l'interpreteur se faisait déjà dans un thread à part (utilisation de glibmm => g_thread_create, compilation cygwin/mingw).
    Je vais opter pour la deuxième solution même si en terme de sécurité c pas terrible, je vais etre obligé de vérifier l'executable que je lance avec un checksum.
    Toujours pas d'idée pour le fork() de cygwin?

    P.S: excellent article pour appeller une méthode C++ avec CreateThread et accéder au données membres de la classe sans être obligé de les mettre en static http://www.intel.com/cd/ids/develope...578.htm?page=7

  4. #4
    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
    J'ai lu quelque part que le noyau WinNT pouvait faire du fork(), mais que ce n'était pas disponible, du moins avec l'API Win32.

    C'est peut-être disponible avec l'API native, mais programmer en natif peut ne marcher que sur une version bien précise de NTDLL.DLL...



    Sinon, plus réaliste: Tu as essayé de faire du Structured Exception Handling dans le thread que tu lances ?
    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.

Discussions similaires

  1. [Turbo Delphi pour Win32]
    Par romero dans le forum Delphi .NET
    Réponses: 3
    Dernier message: 22/02/2007, 02h04
  2. Problème de compilation avec dev-c++ pour WIN32 API
    Par ValyGator dans le forum Dev-C++
    Réponses: 2
    Dernier message: 08/01/2007, 14h53

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