Linux中的进程问题,以及exit(0); 和sleep(5);

发布网友

我来回答

1个回答

热心网友

俺跟你解释一下:

fork是copy一个跟当前进程一模一样的进程,包括当前进程的所有状态(有特殊设置就不会拷贝,如文件标识)。子进程如果不设置新的执行程序,会继续执行fork之后的代码,注意前面提过的copy跟父进程一模一样的代码。

pid==0代表是子进程,因此子进程会执行这段代码:

if(pid==0)
{
    printf("child!!!\n");
    //这里会造成子进程的主线程,main执行线程,阻塞5秒
    sleep(5);
    exit(0);
}

pid > 0 代表是父进程,因此父进程继续执行的代码为:

if(pid>0)
{
    //此处必须等待子进程结束,子进程调用exit(0),时会通知父进程继续执行
    //属于进程间通讯、同步的一个手段之一。那子进程等待5秒被唤醒,执行exit(0)
    //父进程收到通知,获取到子进程的退出状态,继续就会printf,基本也就是等待了5秒
    //然后父进程return 0 等价于exit(0)正常结束
    wait(NULL);//不这样写,父进程直接结束可能会产生僵尸进程,也可能变成孤儿进程由
    //由init进程领养,并正确结束。通用的做法必须wait。根据操作系统以及版本不同处理
    //方式可能不一样,如aix可能就会有僵尸进程产生
    printf("father!!!\n");
}

热心网友

俺跟你解释一下:

fork是copy一个跟当前进程一模一样的进程,包括当前进程的所有状态(有特殊设置就不会拷贝,如文件标识)。子进程如果不设置新的执行程序,会继续执行fork之后的代码,注意前面提过的copy跟父进程一模一样的代码。

pid==0代表是子进程,因此子进程会执行这段代码:

if(pid==0)
{
    printf("child!!!\n");
    //这里会造成子进程的主线程,main执行线程,阻塞5秒
    sleep(5);
    exit(0);
}

pid > 0 代表是父进程,因此父进程继续执行的代码为:

if(pid>0)
{
    //此处必须等待子进程结束,子进程调用exit(0),时会通知父进程继续执行
    //属于进程间通讯、同步的一个手段之一。那子进程等待5秒被唤醒,执行exit(0)
    //父进程收到通知,获取到子进程的退出状态,继续就会printf,基本也就是等待了5秒
    //然后父进程return 0 等价于exit(0)正常结束
    wait(NULL);//不这样写,父进程直接结束可能会产生僵尸进程,也可能变成孤儿进程由
    //由init进程领养,并正确结束。通用的做法必须wait。根据操作系统以及版本不同处理
    //方式可能不一样,如aix可能就会有僵尸进程产生
    printf("father!!!\n");
}

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com