fork函数的作用
一个进程,包括代码、数据和分配给进程的资源。fork()函数通过系统调用创建一个与原来进程几乎完全相同的进程,也就是两个进程可以做完全相同的事,但如果初始参数或者传入的变量不同,两个进程也可以做不同的事。
一个进程调用fork()函数后,系统先给新的进程分配资源,例如存储数据和代码的空间。然后把原来的进程的所有值都复制到新的新进程中,只有少数值与原来的进程的值不同。相当于克隆了一个自己。
fork出错可能有两种原因:
1)当前的进程数已经达到了系统规定的上限,这时errno的值被设置为EAGAIN。
2)系统内存不足,这时errno的值被设置为ENOMEM。
创建新进程成功后,系统中出现两个基本完全相同的进程,这两个进程执行没有固定的先后顺序,哪个进程先执行要看系统的进程调度策略。
root@localhost:~# vi fork_test.c
#include <unistd.h>
#include <stdio.h> int main()
{
pid_t fpid;
int count = ; printf("start \n"); fpid = fork(); printf("fork \n"); if(fpid<)
{
printf("error in fork! \n");
}
else if (fpid==)
{
printf("child process %d \n",getpid());
count ++;
}
else
{
printf("parent process %d \n",getpid());
count ++;
}
printf("统计结果是:%d \n",count);
return ;
}
root@localhost:~# gcc fork_test.c -o fork_test
root@localhost:~# ./fork_test
输出结果如下:
start
fork
parent process
统计结果是:
root@localhost:~# fork
child process
统计结果是:
总结: fork函数 会创建一个新进程,pid为0时是子进程 ,pid 不为零时是父进程。
子进程执行是从fork开始执行的。fork之前的,不用再次执行。
参考文档:http://www.cnblogs.com/jeakon/archive/2012/05/26/2816828.html