gpt4 book ai didi

c - 不复存在的进程,fork()

转载 作者:行者123 更新时间:2023-12-04 05:05:17 30 4
gpt4 key购买 nike

如果我运行这个程序,我的进程会失效吗?我正在尝试创建一个主程序,该程序并行运行 5 个进程,然后不会得到失效的进程。问题主要是要确保这不会发生。我不太确定我到目前为止是否做得对。我听说通过为尽可能多的被“fork()”ed 的子进程设置“wait()”来确保你没有失效的进程是一种很好的做法。

#include <time.h>
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
#include <stdlib.h>

void forkChildren(int nrofChildren, int *nr_of_children) {
pid_t pid;
int i;
for(i=0; i<5; i++) {
/* fork a child process */
pid = fork();
(*nr_of_children)++;
/* error occurred */
if (pid < 0) {
fprintf(stderr, "Fork failed\n");
exit(-1);
}
/* successful child */
else if (pid == 0) {
int sleeptime=1; //rand()%10;
printf("I am child: %d \nwith parent: %d \nin loop: %d \nand will sleep for: %d sec\n\n", getpid(), getppid(), i, sleeptime);
sleep(sleeptime);
printf("Ending of child: %d \nwith parent :%d in loop: %d\n\n", getpid(), getppid(), i);
}
/* parent process
else {
wait(NULL); Do I need this to make sure I dont get defunct processes???
} */
}
}


int main(int argc, char *argv[]) {
srand((unsigned int)time(NULL));
int nr_of_children=0;
if (argc < 2) {
/* if no argument run 5 childprocesses */
forkChildren(5, &nr_of_children);
} else {
forkChildren(atoi (argv[1]), &nr_of_children);
}
wait(NULL);
printf("End of %d, with %d nr of child-processes\n\n", getpid(), nr_of_children);
return 0;
}

最佳答案

是的,您需要wait关于子进程。原因是否则仍然会有与现在僵死进程相关的数据,例如进程返回值的空间。

关于c - 不复存在的进程,fork(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15587500/

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