- fork()函数
(1).使用fork()函数创建进程,将会返回两个值,在父进程中将会返回子进程的进程ID,在子进程中将会返回0
(2).fork()将会复制主进程的数据空间,堆,栈等资源,也就是说子进程与父进程数据将不再共享,只共享了代码段
(3)fork()函数在调用之后,将会直接执行父进程和子进程,无先后关系 - vfork()函数
(1)使用vfork函数创建进程,返回值与fork函数一致
(2)vfork函数执行之后,在子进程exec和exit(0)之前,子进程将与主进程共享数据空间
(3)fork()函数在调用之后,必须在调用exec之后或exit(0)之后,父进程才将会被执行
一.测试fork()函数
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
int main()
{
pid_t child;
if((child=fork())==-1)
{
printf("Fork error");
exit(1);
}
if(child==0)//子进程
{
printf("子进程的pid为%d\n",getpid());
exit(0);
}else //主进程
{
printf("主进程的pid为%d\n",getpid());
exit(0);
}
}
编译与执行:
//编译
gcc fork.c -o fork
//执行
./fork
结果:一般来说,父进程和主进程是不分先后同时运行的,但是由于该程序代码较少,运行时可能因为子进程要执行复制等功能所以父进程一直比子进程快
主进程的pid为2449
子进程的pid为2450
二:测试vfork()函数
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
int main()
{
pid_t child;
if((child=vfork())==-1)
{
printf("Fork error");
exit(1);
}
if(child==0)//子进程
{
sleep(1);
printf("子进程的pid为%d\n",getpid());
exit(0);
}else //主进程
{
printf("主进程的pid为%d\n",getpid());
exit(0);
}
}
~
编译与执行与上述一致
//一秒之后同时显示,且总是子进程优先于主进程显示
子进程的pid为2539
主进程的pid为2538