gpt4 book ai didi

c - 使用管道的两个进程的环

转载 作者:太空宇宙 更新时间:2023-11-04 06:07:46 24 4
gpt4 key购买 nike

我有这个管道和 dup 使用的例子。它应该创建一个由管道连接的两个进程组成的环。这是代码:

#include <unistd.h>

#define READ 0
#define WRITE 1

main (int argc, char *argv[]) {
int fd[2];
pipe(fd); //first call to pipe
dup2(fd[READ],0);
dup2(fd[WRITE],1);
close(fd[READ]);
close(fd[WRITE]);
pipe(fd); //second call to pipe

if (fork()==0) {
dup2(fd[WRITE],1);
} else
dup2(fd[READ],0);

close(fd[READ]);
close(fd[WRITE]);
}

从“两个进程的环”我了解到,进程A的输出连接到进程B的输入,进程B的输出连接到进程A的输入。

在第一次调用 pipe 和连续两次调用 dup2 之后,我认为标准输入和输出被重定向到我的新管道的输入和输出。

然后,第二次调用 pipe 使我感到困惑,因为我认为它覆盖了我以前的 fd 值。此时标准输入输出是怎么回事?

最后,fork 调用:

child 是否将标准输出重定向到管道?

父级是否将标准输入重定向到管道?

我在这里看不到戒指。

我希望我说清楚了,因为我真的很困惑。

非常感谢!!

最佳答案

好吧,让我们假设您是从终端启动这件事的。那么你有:

file 0 (stdin)  = terminal keyboard
file 1 (stdout) = terminal screen
file 2 (stderr) = terminal screen

现在你运行 pipe(fd),你有:

file 0-2 = as before
file 3 (fd[0]) = read end of pipe 1
file 4 (fd[1]) = write end of pipe 1

现在运行前两个 dup2 和前两个 close:

file 0 = read end of pipe 1
file 1 = write end of pipe 1
file 2 = still terminal screen
file 3-4 = now closed

现在你制作一个新的管道:

file 0-2 as before
file 3 (fd[0]) = read end of pipe 2
file 4 (fd[1]) = write end of pipe 2

现在你 fork 了。在子进程中,您调用 dup2(fd[1],1) 并关闭两个 fd(您的来源在这里不太正确):

file 0: read end of pipe 1
file 1: write end of pipe 2
file 2: terminal screen
file 3-4: closed

在您调用 dup2(fd[0],0) 的父进程中,再次关闭两个 fd 给它:

file 0: read end of pipe 2
file 1: write end of pipe 1
file 2: terminal screen
file 3-4: closed

所以我们让父进程将其标准输出写入管道 1,子进程从中读取其标准输入。类似地,我们让父进程从管道 2 读取其标准输入,子进程将其标准输出写入管道 2。即,两个进程的环。

我总是被告知这种安排很容易出现死锁。我不知道更现代的 Unix 是否也是如此,但值得一提。

关于c - 使用管道的两个进程的环,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6288241/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com