Итак, я пытался запустить системную команду (или exec или что-то еще) в дочернем процессе после fork() и передать ему некоторый ввод, а затем получить его вывод. Это выглядит так после fork(), а pc и cp — это каналы parent-child и child-parent.
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);
Теперь он работает хорошо (если вам нужен код: http://pastebin.com/Fh7GrxYm), но когда я разговаривал с #posix на irc, они сходили с ума по поводу того, как это потенциально может заблокировать и как это «зависит от того, как себя чувствует ядро».
В блоге msdn была запись о том же: http://blogs.msdn.com/b/oldnewthing/archive/2011/07/07/10183884.aspx
Как можно предотвратить блокировку, если таковая имеется и т.д.?