May 8, 200817 yr j'ai une question existentielle a vous soumettre... je pense avoir correctement utilise les thread, sauf que... ben ca marchew pas j'ai bien les messages des printf de ma boucle, pas d'erreurs, et pourtant j'ai pas ceux qui devraient sortir de monthread() vous avez une idee d'ou pourrait venir mon probleme ? void *monthread(void *data) { t_ply *p; p = (t_ply *)data; write(1, "tata\n", 5); printf("thread:%i\n", p->p); } void play(t_ply *p, int n) { int i; t_ply *m; pthread_t threads[n]; m = p; while (m) { printf("pthread_create: %i\n", m->p - 1); if ((i = pthread_create(&threads[m->p - 1], NULL, monthread, (void *)m))) { printf("error (#%i) while creating thread #%i\n", i, m->p); exit(-1); } m = m->next; } } merci pour votre aide ! Edited May 9, 200817 yr by Mephisto
May 8, 200817 yr chez moi ca "marche" en commentant l'appel a "write" (je sais pas dans quoi t'écrit '^^) en ajoutant un "return 0;" à monthread parce que mon compilo me crie qu'il attend son void *
May 9, 200817 yr Author le write ecrit sur le term (1), c'etait pour etre sur que le probleme ne venait pas du printf qui aurait ete trop long a afficher quelque chose quoi qu'il en soit, ca tourne toujours pas grossierement, je compile avec gcc *.c -W -Wall -pedantic -ansi -o toto -lthr sous freebsd pour info, comment tu fais ? (a moins que t'as une meilleure idee sur la cause du probleme ?)
May 9, 200817 yr j' ai compilé sous VS 2k8 '^^ ( honte sur moi ) mais je ne vois aucune raison pour que ca ne marche pas, peut etre à part le return. Et fais attention avec write, la dernière fois que j'avais regardé, il était pas très très thread safe.
May 9, 200817 yr Author ca yest, j'ai trouve ! en rajoutant un usleep() dans le for qui cree les thread, ca passe ! merci quand meme pour ton aide
Archived
This topic is now archived and is closed to further replies.