Donc j'essayais d'exécuter une commande système (ou exec, ou autre) à un processus fils après un fork(), et de lui envoyer une entrée, puis d'obtenir sa sortie . Cela ressemble à ceci après fork(), et pc et cp sont des pipes parent-enfant et parent-enfant.pipe, fork, et IPC non bloquant
case 0:
/* Child. */
close(STDOUT_FILENO); /* Close current stdout. */
dup2(cp[1], STDOUT_FILENO);
close(STDIN_FILENO);
dup2(pc[0], STDIN_FILENO);
close(pc[1]);
close(cp[0]);
execlp("cat", "cat", NULL);
exit(1);
default:
/* Parent. */
/* Close what we don't need. */
printf("Input to child:\n");
string theinput("Hey there baby");
write(pc[1], theinput.c_str(), theinput.size());
close(pc[1]);
cout << "The input : " << theinput << endl;
printf("\nOutput from child:\n");
close(cp[1]);
while(read(cp[0], &ch, 1) == 1)
{
write(1, &ch, 1);
outcount++;
}
exit(0);
Maintenant, il semble fonctionner très bien (si vous voulez que le code: http://pastebin.com/Fh7GrxYm), mais quand je parlais à #posix sur irc, ils devenaient fous, sur la façon dont cela peut potentiellement bloquer, et comment "dépend de la façon dont le noyau se sent".
Il y avait un billet de blog msdn de la même chose: http://blogs.msdn.com/b/oldnewthing/archive/2011/07/07/10183884.aspx
Comment peut-on empêcher le blocage, le cas échéant, etc?