#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
int main()
{
pid_t pid;
pid = vfork();
static int i = 0;
i++;
if(pid<0)
{
perror("vfork()");
exit(1);
}
if(pid==0)
{
printf("this is the child process.\n");
i++;
sleep(5);
printf("i= %d\n",i);
exit(0);
}
else
{
i++;
printf("this is the father process.\n");
printf("i=%d\n",i);
}
return 0;
}
我们先来了解一下fork函数: 一个进程,包括代码,数据和分配给进程的资源,fork函数通过系统调用创建一个与原来进程几乎完全相同的进程(我就在本篇中简单理解为实例的这个程序),一个进程调用了fork函数后,系统就创建了一个子进程。
我们知道,vfork函数是完全共享的创建,新老进程使用相同的资源,完全没有拷贝。当新的进程被创建的时候,父进程就会暂时被阻塞,而子进程则借用父进程的地址空间进行(在上图中可以理解为先执行子进程,再执行父进程,数据共享)。这个状态将持续到子进程结束。还有一个理解程序的重要知识就是vfork函数的一个奇妙之处:它仅仅被调用一次,却能返回两次,它可能有三种不同的返回值:
1)在父进程中,它返回新创建的子进程的进程id;
2)在子进程中,它返回0;
3)如果出现错误,它返回一个负数
程序的执行结果:
当i不被static修饰的时候,执行结果为