cs_Rankin
Messages postés52Date d'inscriptionlundi 29 mars 2004StatutMembreDernière intervention27 avril 2010
-
31 août 2009 à 11:43
cs_Rankin
Messages postés52Date d'inscriptionlundi 29 mars 2004StatutMembreDernière intervention27 avril 2010
-
31 août 2009 à 17:39
Salut à tous,
Je suis en train de développer un petit programme qui utilise les tubes nommés. Ayant rencontré des soucis en voulant rendre les I/O non bloquantes, j'ai décidé d'exporter le code du serveur dans un thread.
Le problème, c'est que mon application est toujours bloquée sur le ConnectNamedPipe().
Je pourrais peut-être chercher de ce côté, mais comme j'ai déjà rencontré ce problème de thread bloquant sur un autre de mes programmes, j'aimerais autant savoir où est-ce que je commets une erreur.
int main()
{
CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)thread(), 0, 0, 0);
while (true)
{
cout<<"Je suis dans la main boucle"<<endl;
Sleep(1000);
}
return 0;
}
Une fois le thread créé, le message du main ne s'affiche jamais... J'ai essayé de réduire la priorité du thread, mais même au minimum ça ne change rien (d'ailleurs le flag CREATE_SUSPENDED même sans resume ne sert à rien chez moi, le thread est quand même lancé...)
J'ai cherché des réponses un peu partout, mais j'ai l'impression que ce problème est très courant. Je ne peux quand même pas croire qu'il s'agisse uniquement d'une mauvaise gestion des threads sous Windows ?
cs_Rankin
Messages postés52Date d'inscriptionlundi 29 mars 2004StatutMembreDernière intervention27 avril 2010 31 août 2009 à 17:39
Merci pour ta réponse, j'ai corrigé ce que tu m'as dit (suppression des parenthèses, suppression du cast, définition du thread en DWORD WINAPI thread(LPVOID lpParam) et un petit return à la fin du code.
Et ça marche. Le pire, c'est que j'ai commencé à travailler de cette façon à partir du MSDN, que j'avais des erreurs, et à force de refaire je me suis éloigné du modèle qui marche... le "thread" était exécuté comme une simple fonction.