用waitpid函数回收进程
waitpid函数:作用同wait,但可指定pid进程清理,可以不阻塞。
原型:pid_t waitpid(pid_t pid, int *status, in options);
返回值:成功时返回清理掉的子进程ID,失败返回-1;当第三个参数被设置为WNOHANG,且子进程还在运行时,返回0;
参数说明:
pid
> 0 回收指定ID的子进程 。
-1 回收任意子进程(相当于wait)。
0 回收和当前调用waitpid一个组的所有子进程。
< -1 回收指定进程组内的任意子进程。
status
存储进程死亡的信息。
options
设置为阻塞或者不阻塞状态。
WNOHANG:不阻塞
0:阻塞
现在有一个题目:父进程fork 3 个子进程,三个子进程一个调用ps命令, 一个调用自定义程序1(正常),一个调用自定义程序2(会出段错误)。父进程使用waitpid对其子进程进行回收。
很简单,就是一些函数的调用。
代码:
#include
<cstdio>
#include
<unistd.h>
#include
<stdlib.h>
#include
<sys/types.h>
#include
<sys/wait.h>
int main()
{
int i = 0;
int status; //存储进程死亡信息
pid_t pid; //存储wait函数返回值
for (; i != 3; i++)
{
if (!fork())
{
break;
}
}
if (i < 3)
{
if (0 == i)
{
int e_ret = execlp("ps", "ps", "aux", NULL);
if (-1 == e_ret)
{
perror("execlp ps error ");
exit(1);
}
}
else
if (1 == i)
{
int e_ret = execl(" / home / lovedan / projects / test / a", "a", NULL);
if (-1 == e_ret)
{
perror("execlp a error ");
exit(1);
}
}
else
if (2 == i)
{
int e_ret = execl(" / home / lovedan / projects / test / b", "b", NULL);
if (-1 == e_ret)
{
perror("execlp b error ");
exit(1);
}
}
}
else
if (i == 3)
{
//while (-1 != (pid = waitpid(-1, &status, WNOHANG)))//这里设置为不阻塞状态
while (-1 != (pid = wait(&status))) //上面那句代码并没有问题。不阻塞的话,那输出真的是群魔乱舞。
{
if (0 == pid)
{
printf("The child process is running and does not recycle.\n");
}
else
if (pid > 0)
{
printf("The recovery sub - process is successful, and his ID is %d .\n", pid);
if (WIFEXITED(status))
{
printf("The subprocess exits normally, and the return value is %d .\n", WEXITSTATUS(status));
}
else
if (WIFSIGNALED(status))
{
printf("The subprocess exits with an exception because it exits with a signal of %d .\n", WTERMSIG(status));
}
}
}
if (-1 == pid)
{
printf("No child processes can be recycled.\n");
}
}
else
{
printf("i value error.i = %d", i);
exit(1);
}
// printf("hello from fork_3_ps_normal_SegmentationFault!\n");
return 0;
}
程序中的a和b是另外的两个小程序,根据题目意思来写的,很简单,代码就不拿上来了。
来看看不阻塞和阻塞状态下的输出:首先是不阻塞的;
The child process is running and does not recycle.
The child process is running and does not recycle.
The child process is running and does not recycle.
The child process is running and does not recycle.
I am a.
The recovery sub-process is successful, and his ID is 449 .
The subprocess exits with an exception because it exits with a signal of 11 .
The recovery sub-process is successful, and his ID is 448 .
The subprocess exits normally, and the return value is 216 .
The child process is running and does not recycle.
The child process is running and does not recycle.
The child process is running and does not recycle.
The child process is running and does not recycle.
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
The child process is running and does not recycle.
The child process is running and does not recycle.
root 1 0.0 0.0 10432 580 ? Ss 08:29 0:00 /init
The child process is running and does not recycle.
The child process is running and does not recycle.
The child process is running and does not recycle.
The child process is running and does not recycle.
lovedan 2 0.0 0.0 25788 3704 tty1 Ss 08:29 0:00 -bash
The child process is running and does not recycle.
root 44 0.0 0.0 80408 912 ? Ss 08:30 0:00 /usr/sbin/sshd
The child process is running and does not recycle.
lovedan 446 0.0 0.0 36172 516 tty1 S 09:06 0:00 ./fork_3_ps_normal_SegmentatThe child process is running and does not recycle.
lovedan 447 0.0 0.0 51704 1832 tty1 R 09:06 0:00 ps aux
The child process is running and does not recycle.
The recovery sub-process is successful, and his ID is 447 .
The subprocess exits normally, and the return value is 0 .
No child processes can be recycled.
完全是群魔乱舞。
来看看阻塞状态下的:
I am a.
The recovery sub-process is successful, and his ID is 727 .
The subprocess exits normally, and the return value is 216 .
The recovery sub-process is successful, and his ID is 728 .
The subprocess exits with an exception because it exits with a signal of 11 .
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
root 1 0.0 0.0 10432 580 ? Ss 08:29 0:00 /init
lovedan 2 0.0 0.0 25788 3708 tty1 Ss 08:29 0:00 -bash
root 44 0.0 0.0 80408 912 ? Ss 08:30 0:00 /usr/sbin/sshd
lovedan 725 0.0 0.0 36172 512 tty1 S 09:10 0:00 ./fork_3_ps_normal_SegmentationFault.out
lovedan 726 0.0 0.0 51704 1832 tty1 R 09:10 0:00 ps aux
The recovery sub-process is successful, and his ID is 726 .
The subprocess exits normally, and the return value is 0 .
No child processes can be recycled.
这就比较好了。满足。
用waitpid函数回收进程的更多相关文章
- wait/waitpid函数与僵尸进程、fork 2 times
一.僵尸进程 当子进程退出的时候,内核会向父进程发送SIGCHLD信号,子进程的退出是个异步事件(子进程可以在父进程运行的任何时刻终止) 子进程退出时,内核将子进程置为僵尸状态,这个进程称为僵尸进程, ...
- 【Linux】僵尸进程,孤儿进程以及wait函数,waitpid函数(有样例,分析很详细)
本文内容: 1.僵尸进程,孤儿进程的定义,区别,产生原因,处理方法 2.wait函数,waitpid函数的分析,以及比较 背景:由于子进程的结束和父进程的运行是一个异步的过程,即父进程永远无法预测子进 ...
- linux多进/线程编程(3)——wait、waitpid函数和孤儿、僵尸进程
当使用fork创建多个进程后,需要解决子进程回收的问题.wait和waitpid函数就是做这个工作的. 假设子进程没有合理的回收,可能会带来两个问题: 1.孤儿进程(父进程挂了,子进程活着),孤儿进程 ...
- 进程控制之wait和waitpid函数
当一个进程正常或异常终止时,内核就向其父进程发送SIGCHLD信号.因为子进程终止是个异步事件(这可以在父进程运行的任何时候发生),所以这种信号也是内核向父进程发的异步通知.父进程可以选择忽略该信号, ...
- 回收进程用户空间资源 exit()函数 _exit()函数 atexit()函数 on_exit()函数
摘要:本文主要讲述进程的终止方式,以及怎样使用exit()函数来终止进程.回收进程用户空间资源:分析了exit()函数与_exit()函数,returnkeyword的差异.同一时候具体解读了怎样使用 ...
- UNIX环境编程学习笔记(21)——进程管理之获取进程终止状态的 wait 和 waitpid 函数
lienhua342014-10-12 当一个进程正常或者异常终止时,内核就向其父进程发送 SIGCHLD信号.父进程可以选择忽略该信号,或者提供一个该信号发生时即被调用的函数(信号处理程序).对于这 ...
- wait函数与waitpid函数(僵尸进程)
当子进程退出时,内核会向父进程发送SIGCHLD信号,子进程的退出是个异步事件(子进程可以在父进程运行的任何时刻终止) 子进程退出时,内核将子进程置为僵尸状态,这个进程称为僵尸进程.它只保留最小的一些 ...
- 进程——wait与waitpid、僵尸进程与孤儿进程
僵尸进程:子进程终止了,但是父进程没有回收子进程的资源PCB.使其成为僵尸进程 孤儿进程:父进程先与子进程结束了,使得子进程失去了父进程,这个时候子进程会被1号进程init进程领养,成为孤儿进程 为了 ...
- waitpid()函数
waitpid函数 作用同于wait,但可指定pid进程清理,可以不阻塞. pid_t waitpid(pid_t pid,int *status,int options);成功:返回清理掉的子进程I ...
随机推荐
- go语言学习--map类型的切片
今天在项目中遇到了一个切片的map,记录下map切片的使用 package main import "fmt" func main() { // Version A: items ...
- mysql查询中取差集的问题
有个场景 现在有个打卡的记录表(daka),记录了用户每天的打卡信息,同时还有个运动打卡表(sport_daka),如果用户有运动打卡则在运动打卡表里面记录. 现在要统计用户的每天的打开信息,包括运动 ...
- Python3 文件的重命名
在Python3中我们要实现将本地文件homework.txt中的内容的修改操作时,大体的思路是这样的:先将homework.txt文件的内容读取到内存中,在内存中对里面的数据进行修改,接着将修改完成 ...
- [UE4]先报告后广播模式
解决客户端射击,在服务器端和其他客户端看不到的问题. 一.把要广播的操作封装成一个事件(函数不支持网络属性),选择“多路传送” 二.创建一个事件,选择“在服务器上运行” 总结:从客户端执行的事件报告到 ...
- Navicat 12 破解方法
1.按步骤安装Navicat Premium,如果没有可以去官网下载:http://www.navicat.com.cn/download/navicat-premium 2.安装好后下载激活文件:h ...
- 6行代码解决golang TCP粘包
转自:https://studygolang.com/articles/12483 什么是TCP粘包问题以及为什么会产生TCP粘包,本文不加讨论.本文使用golang的bufio.Scanner来实现 ...
- [SQL]SQL Server 事务及回滚事务
第一种: Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/ ...
- $.extend与$.fn.extend()
很多情况下,用户需要对jQuery插件进行二次开发,那么我们来看看JQ原开发者为我们提供的两种扩展插件的方式如下: 1.类别类:相当于为jquery扩展一个类,比如现在我要扩展一个简单的想加的功能函数 ...
- 我推荐阅读的微信公众号-IT类
微信,正深刻影响着我们的生活,每个使用微信的人,从微信这个窗口去了解这个世界. 微信公众号,微信生态圈是核心功能之一,每天都有大量的文章创作.传播.转发出来,海量的信息扑面而来,微信阅读成为微信使用者 ...
- cocos源码分析--ClippingNode绘图原理
在OpenGL 绘制过程中,与帧缓冲有关的是模版,深度测试,混合操作.模版测试使应用程序可以定义一个遮罩,在遮罩内的片段将被保留或者丢弃,在遮罩外的片段操作行为则相反.深度测试用来剔除那些被场景遮挡的 ...