vfork和fork的区别

        我们知道, fork会创建一个新的进程, 这个新的进程是当前进程的子进程, 区别在于, fork函数会复制父进程的一些资源, 也就是, 仅仅是复制的关系, 而非共享。 而vfork就不同了, 利用vfork创建的子进程和父进程共享地址空间, 下面, 我们通过实际程序来看看:

        fork函数的简单应用:

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

int main()
{
int a = 0;

pid_t pid;
pid = fork();
if(pid < 0)
{
printf(“error\n”);
return -1;
}
else if(0 == pid)
{
printf(“child\n”);
printf("%d\n", a);
}
else
{
a = 1;
printf(“parent\n”);
printf("%d\n", a);
}

return 0;

}

运行一下, 结果为:

parent

1

child

0

      在pid=fork()之前,只有一个进程在执行,但在这条语句执行之后,就变成两个进程在执行了,这两个进程的共享代码段,将要执行的下一条语句都是if(pid==0)。两个进程中,原来存在的那个进程被称作“父进程“,新出现的那个进程被称作“子进程”,父子进程的区别在于进程标识符(PID)不同。

由此可见, 父进程值的修改, 不会影响到子进程, 为什么呢? 因为他们没有共享地址空间啊。


      我们再看看vfork:

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

int main()
{
int a = 0;

pid_t pid;
pid = vfork();
if(pid < 0)
{
printf(“error\n”);
return -1;
}
else if(0 == pid)
{
a = 1;
printf(“child\n”);
printf("%d\n", a);
_exit(0); // 这个先不管它, 以后再说
}
else
{
printf(“parent\n”);
printf("%d\n", a);
}

return 0;

}
vfork()的一大特点:先调用子进程,等子进程的exit(1)被调用后,再调用父进程
结果为:

child

1

parent

1

     可见, vfork创建的子进程和父进程确实共享着内存空间呢。


    • 1
      点赞
    • 0
      收藏
      觉得还不错? 一键收藏
    • 0
      评论
    评论
    添加红包

    请填写红包祝福语或标题

    红包个数最小为10个

    红包金额最低5元

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

    抵扣说明:

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

    余额充值