wait函数和waitpid函数详解

上传人:洪易 文档编号:39950247 上传时间:2018-05-21 格式:DOCX 页数:7 大小:25.45KB
返回 下载 相关 举报
wait函数和waitpid函数详解_第1页
第1页 / 共7页
wait函数和waitpid函数详解_第2页
第2页 / 共7页
wait函数和waitpid函数详解_第3页
第3页 / 共7页
wait函数和waitpid函数详解_第4页
第4页 / 共7页
wait函数和waitpid函数详解_第5页
第5页 / 共7页
点击查看更多>>
资源描述

《wait函数和waitpid函数详解》由会员分享,可在线阅读,更多相关《wait函数和waitpid函数详解(7页珍藏版)》请在金锄头文库上搜索。

1、#include /* 提供类型 pid_t 的定义 */#include pid_t wait(int *status)进程一旦调用了 wait,就立即阻塞自己,由 wait 自动分析是否当前进程的某个子进程已经退出,如果让它找到了这样一个已经变成僵尸的子进程,wait 就会收集这个子进程的信息,并把它彻底销毁后返回;如果没有找到这样一个子进程,wait 就会一直阻塞在这里,直到有一个出现为止。参数 status 用来保存被收集进程退出时的一些状态,它是一个指向 int 类型的指针。但如果我们对这个子进程是如何死掉的毫不在意,只想把这个僵尸进程消灭掉,(事实上绝大多数情况下,我们都会这样想)

2、,我们就可以设定这个参数为 NULL,就象下面这样:pid = wait(NULL);如果成功,wait 会返回被收集的子进程的进程 ID,如果调用进程没有子进程,调用就会失败,此时 wait 返回-1,同时 errno 被置为 ECHILD。wait 调用例程:/* wait1.c */#include #include #include #include main()pid_t pc,pr;pc=fork();if(pc#include #include main()int status;pid_t pc,pr;pc=fork();if(pc#include main()pid_t pc,

3、 pr;int status;pc=fork();if(pc /* 提供类型 pid_t 的定义 */#include pid_t waitpid(pid_t pid,int *status,int options)从本质上讲,系统调用 waitpid 和 wait 的作用是完全相同的,但 waitpid 多出了两个可由用户控制的参数 pid 和 options,从而为我们编程提供了另一种更灵活的方式。下面我们就来详细介绍一下这两个参数:pid:从参数的名字 pid 和类型 pid_t 中就可以看出,这里需要的是一个进程 ID。但当 pid取不同的值时,在这里有不同的意义。pid0 时,只等待

4、进程 ID 等于 pid 的子进程,不管其它已经有多少子进程运行结束退出了,只要指定的子进程还没有结束,waitpid 就会一直等下去。pid=-1 时,等待任何一个子进程退出,没有任何限制,此时 waitpid 和 wait 的作用一模一样。pid=0 时,等待同一个进程组中的任何子进程,如果子进程已经加入了别的进程组,waitpid 不会对它做任何理睬。pid/include/unistd.h 文件 349-352 行就会发现以下程序段:static inline pid_t wait(int * wait_stat)return waitpid(-1,wait_stat,0);返回值和错

5、误waitpid 的返回值比 wait 稍微复杂一些,一共有 3 种情况:1、当正常返回的时候,waitpid 返回收集到的子进程的进程 ID;2、如果设置了选项 WNOHANG,而调用中 waitpid 发现没有已退出的子进程可收集,则返回 0;3、如果调用中出错,则返回-1,这时 errno 会被设置成相应的值以指示错误所在;当 pid 所指示的子进程不存在,或此进程存在,但不是调用进程的子进程,waitpid 就会出错返回,这时 errno 被设置为 ECHILD;/* waitpid.c */#include #include #include main()pid_t pc, pr;p

6、c=fork();if(pc0) /* 如果 fork 出错 */printf(“Error occured on forking./n“);else if(pc=0) /* 如果是子进程 */sleep(10); /* 睡眠 10 秒 */exit(0);/* 如果是父进程 */dopr=waitpid(pc, NULL, WNOHANG); /* 使用了 WNOHANG 参数,waitpid 不会在这里等待 */if(pr=0) /* 如果没有收集到子进程 */printf(“No child exited/n“);sleep(1);while(pr=0); /* 没有收集到子进程,就回去

7、继续尝试 */if(pr=pc)printf(“successfully get child %d/n“, pr);elseprintf(“some error occured/n“);编译并运行:$ cc waitpid.c -o waitpid$ ./waitpidNo child exitedNo child exitedNo child exitedNo child exitedNo child exitedNo child exitedNo child exitedNo child exitedNo child exitedNo child exitedsuccessfully get child 1526父进程经过 10 次失败的尝试之后,终于收集到了退出的子进程。因为这只是一个例子程序,不便写得太复杂,所以我们就让父进程和子进程分别睡眠了 10秒钟和 1 秒钟,代表它们分别作了 10 秒钟和 1 秒钟的工作。父子进程都有工作要做,父进程利用工作的简短间歇察看子进程的是否退出,如退出就收集它。提示:可以尝试在最后一个例子中把 pr=waitpid(pc, NULL, WNOHANG); 改为pr=waitpid(pc, NULL, 0);或者 pr=wait(NULL);看看运行结果有何变化?(修改后的结果使得父进程将自己阻塞,直到有子进程退出为止!)

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 研究报告 > 综合/其它

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号