gpt4 book ai didi

c - 为什么我的第二个子进程在第一个子进程之前受到攻击?

转载 作者:行者123 更新时间:2023-11-30 16:27:07 26 4
gpt4 key购买 nike

目前,我正在尝试编写一个支持管道的小 shell。在我的函数 execute(char** args, char** args2) 中,它需要两个 char 数组,其中每个命令由分隔符 "" 分隔。第一个参数包含管道之前的命令(例如 {ls, -l}),第二个参数包含管道之后的命令(例如 {wc})。

但是,在我的 execute 函数中,第二个子进程 pid2 首先运行,而第一个子进程 pid1 永远不会被命中。

我不确定我是否遗漏了在 C 中创建自己的管道命令所需的任何内容,并且非常感谢我能获得的任何帮助/建议。

执行函数:

int execute(char** args, char** args2) {
int des_p[2];
pid_t pid1, pid2;
if(pipe(des_p) == -1) {
perror("Pipe failed");
exit(1);
}
pid1 = fork();
if(pid1 == 0) {
printf("AT FIRST CHILD");
dup2(des_p[1], STDOUT_FILENO);
close(des_p[0]);
execvp(args[0], args);
perror("execvp of of FIRST PROCESS failed");
exit(1);
}
pid2 = fork();
if(pid2 == 0) {
printf("AT SECOND CHILD \n");
dup2(des_p[0], STDIN_FILENO);
close(des_p[1]);
execvp(args2[0], args2);
perror("execvp of SECOND PROCESS failed");
exit(1);
}
close(des_p[0]);
close(des_p[1]);
wait(pid1);
wait(pid2);

return 0;
}

最佳答案

第一个子进程正在运行,但由于 stdio 缓冲,您看不到该消息。默认情况下,stdout 是行缓冲的,因此在打印换行符之前缓冲区不会刷新。您打印一条不带换行符的消息,然后在刷新缓冲区之前调用 execvp(),因此缓冲区永远不会刷新,也不会看到该消息。

将其更改为:

    printf("AT FIRST CHILD\n");

关于c - 为什么我的第二个子进程在第一个子进程之前受到攻击?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52863924/

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