首页 > 代码库 > 进程控制fork vfork

进程控制fork vfork

主要函数:

fork 用于创建一个新进程

exit 用于终止进程

exec 用于执行一个程序

wait 将父进程挂起,等待子进程结束

getpid 获取当前进程的进程ID

nice 改变进程的优先级

---------------------------------

孤儿进程:

如果一个子进程的父进程先于子进程结束,子进程就成为一个孤儿进程,他由init进程收养,成为init进程的子进程。

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>


int main() 
{

    pid_t pid;
    pid = fork();
    
    switch( pid )
    {
        case 0:
        {
            while(1)
            {
                printf("child pid:%d, parent pid:%d\n", getpid(), getppid());
                sleep(1);
            }
        }
        case -1:
        {
            printf("create child process error\n");
            exit(-1);
        }
        default:
        {
            sleep(3);
            printf("I am parent,pid:%d\n", getpid());
            exit(0);
        }

    }

    return 0;
    
}

 

child pid:9670, parent pid:9669
child pid:9670, parent pid:9669
child pid:9670, parent pid:9669
I am parent,pid:9669
root@wilson-software:~/Project/xa# child pid:9670, parent pid:1
child pid:9670, parent pid:1
child pid:9670, parent pid:1
child pid:9670, parent pid:1
child pid:9670, parent pid:1
child pid:9670, parent pid:1

从输出结果来看,父进程停止后,子进程变成了孤儿进程,此时子进程的父进程ID 是 1,

(init进程的进程ID值始终是1)由init进程收养。

------------------------------------------------------------------------------

vfork函数创建一个子进程时,操作系统并不将父进程的地址空间完全复制到子进程,用vfork函数创建的子进程共享父进程的地址空间,

也就是说子进程完全运行在父进程的地址空间上。子进程对该地址空间中任何数据的修改同样为父进程所见。

使用fork创建一个子进程时,哪个进程先执行取决于系统的调度。

而vfork创建一个子进程时,vfork保证子进程先运行,当他调用exec或者exit之后,父进程才可能被调度执行。

如果在调用exec或者exit之前子进程要依赖父进程的某个行为,就会导致死锁。

如果创建子进程的目的只是为了调用exec执行某个程序,那么fork过程中子进程对父进程地址空间的复制将会是一个多余的过程。

vfork不会拷贝父进程的地址空间,这大大减小了系统开销。

使用vfork时要谨慎,最好不要允许子进程修改与父进程共享的全局变量和局部变量

 

进程控制fork vfork