我需要使用fork()
andwait()
函数来完成作业。我们正在对非确定性行为进行建模,fork()
如果存在多个可能的转换,则需要该程序。
为了尝试弄清楚如何fork
工作wait
,我刚刚制作了一个简单的程序。我想我现在明白了调用是如何工作的,如果程序只分支一次就可以了,因为父进程可以使用单个子进程的退出状态来确定子进程是否达到接受状态。
正如您从下面的代码中看到的那样,我希望能够处理必须有多个子进程的情况。我的问题是您似乎只能使用一次_exit
功能设置状态。因此,在我的示例中,父进程测试的退出状态显示第一个子进程发出 0 作为其退出状态,但没有关于第二个子进程的信息。
我尝试简单地_exit()
拒绝拒绝,但随后该子进程将继续进行,实际上似乎有两个父进程。
对不起华夫饼,但如果有人能告诉我我的父进程如何获得多个子进程的状态信息,我将不胜感激,或者我很高兴父进程只注意到来自子进程的接受状态,但在那种情况下,我需要成功退出具有拒绝状态的子进程。
我的测试代码如下:
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <errno.h>
#include <sys/wait.h>
int main(void) {
pid_t child_pid, wpid, pid;
int status = 0;
int i;
int a[3] = {1, 2, 1};
for(i = 1; i < 3; i++) {
printf("i = %d\n", i);
pid = getpid();
printf("pid after i = %d\n", pid);
if((child_pid = fork()) == 0) {
printf("In child process\n");
pid = getpid();
printf("pid in child process is %d\n", pid);
/* Is a child process */
if(a[i] < 2) {
printf("Should be accept\n");
_exit(1);
} else {
printf("Should be reject\n");
_exit(0);
}
}
}
if(child_pid > 0) {
/* Is the parent process */
pid = getpid();
printf("parent_pid = %d\n", pid);
wpid = wait(&status);
if(wpid != -1) {
printf("Child's exit status was %d\n", status);
if(status > 0) {
printf("Accept\n");
} else {
printf("Complete parent process\n");
if(a[0] < 2) {
printf("Accept\n");
} else {
printf("Reject\n");
}
}
}
}
return 0;
}