forking是Unix和Linux最重要的一个点。
总结下其特点如下:
1,子进程与父进程的复制关系:
子进程拥有父进程的所有内存的精确副本。当使用fork给进程分叉时,它会创建一个自己的副本。在多线程环境中,fork意味着执行的线程是重复的,但是可以分开。因此,有的学者认为fork很像生物里克隆的概念。子进程克隆了父进程。获取了父进程的数据和代码。
2,相互独立关系
父进程和子进程的执行是相互独立的。fork操作为子进程创建了一个单独的地址空间。子进程从操作系统接收一个新的进程号PID号(PID,进程标识符)。
3,fork()的返回值:
fork的返回值决定当前正在进行的是哪一个进程:
0: 处于子进程中;
正值:处于父进程中;
负值:意味着操作系统在尝试调用Fork()函数时,发生了错误。
4,使用Fork需要导入os模块
import os
5,子进程的退出
子进程退出必须使用os.exit(0),否则子进程将返回到父进程中。
例:
import os
def child():
print('\nA new child ', os.getpid())
os._exit(0)
def parent():
while True:
newpid = os.fork()
if newpid == 0:
child()
else:
pids = (os.getpid(), newpid)
print("parent: %d, child: %d\n" % pids)
reply = input("q for quit / c for new fork")
if reply == 'c':
continue
else:
break
parent()
每当用户输入“c”时,它就会分叉。子进程和父进程都在“如果newpid==0:”语句之后继续。在父进程中,newpid的值大于0,在子进程中是0。
运行结果如下:
parent: 5280, child: 5281
A new child 5281
q for quit / c for new forkc
parent: 5280, child: 5282
q for quit / c for new fork
A new child 5282
c
parent: 5280, child: 5283
q for quit / c for new fork
A new child 5283
c
parent: 5280, child: 5284
q for quit / c for new fork
A new child 5284
父进程的PID号为5280,每输入一个“c”获得一个新的子进程,PID号分别为5281,5282,5283等。