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