[英]Simple multiple child exec'd fork segfaulting when trying to read from stdout of child
[英]fork/exec: child exits when trying to redirect stdin/stdout
我正在尝试使用fork / exec从我的程序中控制类似shell的进程,使用管道将命令写入该进程并读取其输出。 如果我创建该进程而没有任何重定向,则它会按预期运行而不会退出-我可以在ps输出中看到父级和子级。 但是,一旦我添加了重定向代码,该子级似乎立即退出(在ps中显示为“ defunct”)。 我不确定如何确定子进程为何退出(我看不到该进程的任何输出),所以我在努力诊断问题。
我的代码如下所示:
int in[2], out[2];
FILE *in_fp, *out_fp;
pipe(in);
pipe(out);
if (fork()) {
close(in[0]);
close(out[1]);
in_fp = fdopen(in[1], "w");
out_fp = fdopen(out[0], "r");
// Here I'll use in_fp and out_fp to communicate with the child.
} else {
dup2(in[0], STDIN_FILENO);
dup2(out[1], STDOUT_FILENO);
close(in[0]);
close(in[1]);
close(out[0]);
close(out[1]);
execlp("child_process", NULL);
}
有谁知道为什么这可能行不通,或者建议我如何获得有关子进程为何退出的更多信息?
编辑:因此strace揭示了子进程正在使用SIGSEGV崩溃,并且看起来像在Py_SetProgramName中-尽管尚不能弄清原因(无法访问子代的符号)。
问题可能出在对execlp()
的调用中。
尽管从技术上讲,参数列表可能为空,但通常的做法是始终至少添加一个参数,该参数在main()
为argv[0]
,其实际名称用于调用程序。 可能是python程序使用此arg0
作为Py_SetProgramName()
参数,而不检查NULL
。
所以写:
execlp("child_process", "child_process", (char*)NULL);
另请注意,引用自man execlp
:
参数列表必须以空指针终止,并且由于它们是可变参数函数,因此必须将该指针强制转换为
(char *)NULL
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.