vfork也是创建一个子进程:
1. 子进程没有(退出)或者运行其他程序则父进程是阻塞的 ,也就意味着子进程是先运行的。
子进程退出(不能在main函数中return)之后,父进程才能运行
2. 子进程先运行的原因:
因为创建出子进程,大多时候都是为了让它运行其他程序
3. 父进程阻塞的原因:
vfork创建子进程后,父子进程是共用一块虚拟地址空间
那么他们共用同一个栈区,有可能会造成调用栈混乱
vfork设计出来的目的就是为了创建一个子进程,然后直接运行其他的程序。重新运行其他的程序就是重新给子进程开辟新的空间,更新它自己的一份地址空间和页表自从fork函数使用了写时拷贝技术之后,这个函数就淘汰了。
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
int main()
{
int pid = vfork();
if (pid == 0) {
printf("this is child!!\n");
exit(0);
}else if (pid > 0) {
while(1) {
printf("this is parent!!\n");
sleep(1);
}
}
return 0;
}