上一篇文章: Python进程专题总览篇
下一篇文章: Python进程专题2:multiprocessing建立进程
该方法只能在unix/Linux/Mac上运行,windows不能够运行。程序执行到fork()时,操做系统会建立一个新进程(子进程),并把父进程的全部信息赋值到子进程中。算法
这个方法很特殊,会有两次返回,分别在子进程和父进程返回一次,子进程永远返回0,父进程返回进程的id.segmentfault
getpid():返回当前进程的idwindows
getppid():返回当前进程父进程的id。操作系统
实例:unix
import os id=os.fork() index=0 if id<0: print("子进程建立失败了") elif id==0: index+=1 print("我是子进程(%d),个人父进程是:%d,index=%d"%(os.getpid(),os.getppid(),index)) else: index += 1 print("我是父进程:%d,个人子进程是:%d,index=%d"%(os.getpid(),id,index))
结果:code
我是父进程:9735,个人子进程是:9736,index=1 我是子进程(9736),个人父进程是:9735,index=1
从上面实例也能够看出:每一个进程的全部数据(包括全局变量)都各持一份,互不影响。进程
屡次fork()可发现:父子进程执行顺序没有规律,彻底取决于操做系统的调度算法。ip