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创建的子进程和父进程确实共享着内存空间呢。


发布了52 篇原创文章 · 获赞 6 · 访问量 3055

猜你喜欢

转载自blog.csdn.net/lx123010/article/details/104168417