浅析fork函数

1、fork函数的原型

pid_t fork();
返回值:若成功调用一次则返回两个值,子进程返回0,父进程返回子进程的进程id,否则,出错返回-1.

2、调用fork时发生的事

一个进程调用fork()函数后,系统先给新的进程分配资源,例如数据空间、堆、栈等资源。然后把原来的进程的所有值都复制到新的新进程中,只有少数值与原来的进程的值不同。相当于克隆了一个自己。所以子进程拥有独立的地址空间。
创建新进程成功后,系统中出现两个基本完全相同的进程,这两个进程执行没有固定的先后顺序,哪个进程先执行要看系统的进程调度策略。

3、fork可能出错的原因

  • 当前进程数量已经达到了系统规定的上限;
  • 系统内存不足;

4、什么是写时复制

现在的linux内核在实现fork函数时,往往在创建子进程时并不立即复制父进程的数据段和堆栈段,此时父进程和子进程共享内存,只有当父进程或者子进程修改了内存内容时才会去复制父进程的数据段和堆栈段,并给子进程分配进程空间,将父进程的内容复制过来,然后继续后面的操作,这个就叫做写时复制。

你可能感兴趣的:(浅析fork函数)