如果对中间的零碎的讲解没有兴趣,可以直接跳到文章末尾,看总结。
一、fork基础知识
一个进程,包括代码、数据和分配给进程的资源。fork()函数通过系统调用创建一个与原来进程几乎完全相同的进程,也就是两个进程可以做完全相同的事,但如果初始参数或者传入的变量不同,两个进程也可以做不同的事。
一个进程调用fork()函数后,系统先给新的进程分配资源,例如存储数据和代码的空间。然后把原来的进程的所有值都复制到新的新进程中,只有少数值与原来的进程的值不同。相当于克隆了一个自己。
fork()函数得到的子进程,继承父进程的所有系统资源,包括,代码段、数据区、常量区等等。父子进程的地址空间开始是共享的,只有当父子进程中的任何一个企图修改其中的内容时才进行复制,即copy on write。(写时复制技术我会在另外一篇博客中进行详细讲解)。而从表明上看二者是互不相干的。
看一个简单例子:
#include <unistd.h>
#include <stdio.h>
int main ()
{
pid_t fpid; //fpid表示fork函数返回的值
int count=0;
fpid=fork();
if (fpid < 0)
printf("error in fork!");
else if (fpid == 0) {
printf("i am the child process, my process id is %d\n",getpid());
count++;
}
else {
printf("i am the parent process, my process id is %d\n",getpid());
count++;
}
printf("count is: %d\n",count);
return 0;
}
结果:
i am the parent process, my process id is 5573
count: 1
i am the child process, my process id is 5574count: 1
为什么两个进程的fpid不同呢,这与fork函数的特性有关。
fork调用的一个奇妙