wait系统调用解析

一、在介绍wait系统调用之前,先看一下僵尸进程:

系统在调用exit()后,进程还没有马上消失掉,还残留一些信息:PID、退出状态。僵尸进程对系统毫无作用!

 

 

//下面的程序中,由于子进程已经结束,而父进程在休眠中,无法对子进程收集=>出现僵尸进程60秒。

#include<sys/types.h>
#include<unistd.h>
#include<stdio.h>
#include<stdlib.h>
int main(){
    pid_t pid;
    pid = fork();
    if(pid < 0) //如果出错
        printf("Err occurred!/n");
    else if(pid == 0) //only 子进程
        exit(0);
    else            //only 父进程
        sleep(60);
   
    //收集僵尸进程
    wait(NULL);       
}

 

===================

explore@ubuntu:~/Documents/Linux C Programming/Process/wait$ gcc zombie.c
explore@ubuntu:~/Documents/Linux C Programming/Process/wait$ ./a.out&
[1] 3318
explore@ubuntu:~/Documents/Linux C Programming/Process/wait$
======

explore@ubuntu:~/Documents/Linux C Programming/Process/wait$ ps -ax
...

 3318 pts/0    S      0:00 ./a.out
 3319 pts/0    Z      0:00 [a.out] <defunct>
 3324 pts/0    R+     0:00 ps -ax

 

 

========================================================

二、wait()具体应用:

 

=====================&status = NULL ==========================

//父进程的wait调用一直在等待,僵尸进程的出现

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

int main(){
    pid_t pid_c, pid_p;
    pid_c = fork();
    if(pid_c < 0){
        printf("ERR occurred!/n");
    }else if(pid_c == 0){  //子进程
        printf("This is Child Process with PID %d./n", getpid());
        sleep(10);
    }else{ //父进程
        pid_p = wait(NULL);
        printf("Parent Process catch a Zombie Process with PID %d./n", pid_p);
    }
   
    exit(0);
}

 

======

explore@ubuntu:~/Documents/Linux C Programming/Process/wait$ gcc wait.c
explore@ubuntu:~/Documents/Linux C Programming/Process/wait$ ./a.out
This is Child Process with PID 3605.
Parent Process catch a Zombie Process with PID 3605.
explore@ubuntu:~/Documents/Linux C Programming/Process/wait$ time ./a.out
This is Child Process with PID 3607.
Parent Process catch a Zombie Process with PID 3607.

real    0m10.003s
user    0m0.000s
sys    0m0.000s
explore@ubuntu:~/Documents/Linux C Programming/Process/wait$

 

 

========================status非NULL===========================

/*

关于wait(int *status)的参数有两个宏来帮助收集僵尸进程的信息。

1.WIFEXITED(status)判断被收集进程是否为正常退出,返回值=0(非正常退出);返回值=非0(正常退出)

2.WEXITSTATUS(status)用来提取子进程的返回值,如果是exit(4)退出,则WEIXTSTATUS(status)的返回值为4。

*/

 

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

int main(){
    int status;
    pid_t pid_c, pid_p;
    pid_c = fork();
    if(pid_c < 0){
        printf("ERR occurred!/n");
    }else if(pid_c == 0){  //子进程
        printf("This is Child Process with PID %d./n", getpid());
        exit(3);
    }else{ //父进程
        pid_p = wait(&status);
        if(WIFEXITED(status)){ //WIFEXITED返回非0值
            printf("The Child Process %d exit normally./n", pid_c);   
            printf("The return Code is %d./n", WEXITSTATUS(status));       
        }else{        //WIFEXITED返回0
            printf("The Child Process %d exit abnormally./n", pid_c);
        }
    }
   
    exit(0);
}
=====编译运行============

explore@ubuntu:~/Documents/Linux C Programming/Process/wait$ gcc wait_status.c
explore@ubuntu:~/Documents/Linux C Programming/Process/wait$ ./a.out
This is Child Process with PID 3640.
The Child Process 3640 exit normally.
The return Code is 3.

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值