1.fork是linux/unix中专有的用来创建进程的系统调用。
2.在linux/unix系统中,提供fork()系统函数,非常特殊。普通的系统调用,调用一次就返回一次,而fork()调用一次,会返回两次,一次是当前进程(父进程),另一个是子进程(即由当前进程复制的一份),然后,分别独自运行,互不干扰,调用的先后顺序由操作系统的调度算法决定。
3.其中需要注意,子进程永远返回0,而父进程则返回子进程的ID(>0的数)。这样做的原因是因为:一个父进程可以fork出很多子进程,父进程需要记下每个子进程的ID,而子进程的父进程是唯一的,只需要调用getppid()就可以拿到父进程的ID。
4.fork出两个进程时,是相互独立运行的,享有相同的数据资源,因而一个进程对全局变量的更改,并不会影响到另一个进程里全局变量的变化。
5.在一个程序里,如果有多次fork调用,则会产生多个进程(一般为2^n),由此,可能会出现“fork炸弹”,即无限次的调用fork产生进程,不断占用内存,最后导致奔溃。即
import os
while True:
os.fork()