子进程先于父进程退出,父进程又没有处理子进程的退出状态,此时子进程会存留PCB在内存中,大量这样的子进程(僵尸进程)会浪费系统的内存资源
以下为解决方式:
1.os.wait()阻塞等待回收子进程
缺点:父进程会阻塞,影响运行效率
pid,status = os.wait()
功能:在父进程中阻塞等待处理子进程退出
返回值:pid 退出的子进程的PID status 子进程退出状态
import os
pid = os.fork()
if pid < 0:
print('Error')
elif pid == 0:
print('Child process:',os.getpid())
os._exit(1) #子进程退出,1为进程退出状态
else:
pid,status = os.wait() #阻塞等待回收子进程
print('pid:',pid)
print('status:',status) #打印出子进程退出状态
while True: #让父进程不退出
pass
- 父进程忽略子进程退出信号,直接让系统来处理子进程退出
signal.signal(signal.SIGCHLD,signal.SIG_IGN)
import os
import signal
#父进程忽略子进程退出信号,让操作系统来处理,父进程不会阻塞
signal.signal(signal.SIGCHLD,signal.SIG_IGN)
pid = os.fork()
if pid < 0:
print('Create process failed')
elif pid == 0:
print('Child process:',os.getpid())
else:
print('Parent process')
while True:
pass
- 创建二级子进程,二级子进程的父进程(一级子进程直接退出)
from time import sleep
import os
def f1():
for i in range(3):
sleep(2)
print('写代码')
def f2():
for i in range(2):
sleep(4)
print('测代码')
pid = os.fork()
#一级子进程执行
if pid == 0:
#子进程再创建二级子进程,让二级子进程干活,自己只是创建二级子进程后就退出
p = os.fork()
if p == 0: #二级子进程干活
f1()
else:
os.wait()
f2() #父进程执行