fork2.C #include <stdio.h> main( { int p1,p2; while((p1=fork( )==-1);/*创建子进程p1*/ _if (p1==0) putchar('b'); else while((p2=fork( )==-1);/*创建子进程p2*/ if(p2==0) putchar('c'); else putchar('a'): 修改实验二fork2的程序,将wait() 放至putchar('a°)语句之前,记录结果并分析原因。
时间: 2024-02-12 22:03:47 浏览: 38
修改后的程序如下:
```C
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/wait.h>
int main() {
int p1, p2, status;
while((p1 = fork()) == -1); /*创建子进程p1*/
if (p1 == 0) {
putchar('b');
} else {
while((p2 = fork()) == -1); /*创建子进程p2*/
if (p2 == 0) {
putchar('c');
} else {
wait(&status);
putchar('a');
}
}
return 0;
}
```
原程序中,等待子进程结束的 `wait` 函数被放在了最后,导致在打印 'a' 前可能会先打印 'b' 或 'c'。因为子进程的运行顺序是不确定的,而且可能在父进程之前结束。所以我们需要将 `wait` 函数移动到打印 'a' 前,让父进程先等待子进程结束,再打印 'a'。这样就能保证输出结果的正确性了。
相关问题
给以下代码加注释:[root@localhost root]# vi 5-1.c #include<stdio.h> #include<stdlib.h> main() { int p1,p2; while(-1==(p1=fork())); if(0==p1) printf("son process,ppid is %d, pid is %d \n\n",getppid(),getpid()); else { while(-1==(
注释如下:
```
[root@localhost root]# vi 5-1.c // 打开编辑器,开始编辑5-1.c文件
#include<stdio.h> // 引入标准输入输出头文件
#include<stdlib.h> // 引入标准库头文件
main() { // 主函数入口
int p1,p2; // 定义两个进程ID变量
while(-1==(p1=fork())); // 在父进程中循环调用fork函数,直到fork返回值不为-1,即创建子进程成功,将子进程ID赋值给p1变量
if(0==p1) // 如果p1的值为0,说明当前进程为子进程
printf("son process,ppid is %d, pid is %d \n\n",getppid(),getpid()); // 输出子进程的信息,包括父进程ID和子进程ID
else // 否则,说明当前进程为父进程
{
while(-1== // 在循环中,调用fork函数创建第二个子进程,直到创建成功
(p2=fork()));
if(0==p2) // 如果p2的值为0,说明当前进程为第二个子进程
printf("son process 2,ppid is %d, pid is %d\n",getppid(),getpid()); // 输出第二个子进程的信息,包括父进程ID和子进程ID
else // 否则,说明当前进程为父进程
printf("parent process, pid is %d\n", getpid()); // 输出父进程的信息,即父进程ID
}
}
```
这段代码实现了在父进程中创建两个子进程,并分别输出它们的进程ID和父进程ID。主要使用了fork函数创建子进程,以及getpid和getppid函数获取进程的ID信息。
# include<stdio.h> # include<signal.h> # include<unistd.h> void waiting(); void stop(); int main(void) { int p1, p2; signal(SIGINT,stop); while((p1=fork())= =-1); if(p1>0)
{
while((p2=fork())==-1);
if(p2>0)
{
waiting(); // 等待子进程结束
kill(p2, SIGKILL); // 终止子进程p2
}
else if(p2==0)
{
execl("/bin/sh", "sh", "-c", "echo child process 2; exit 0", (char*)0);
}
}
else if(p1==0)
{
execl("/bin/sh", "sh", "-c", "echo child process 1; exit 0", (char*)0);
}
return 0;
}
void waiting()
{
printf("Waiting for child processes to finish...\n");
sleep(5);
}
void stop()
{
printf("Received SIGINT signal, terminating all child processes...\n");
kill(0, SIGKILL); // 终止所有进程组
}
这是一个简单的在Linux系统下使用fork实现多进程的程序,并且在父进程接收到SIGINT信号时,终止所有子进程的程序段。