一、创建并开启子进程的两种方式
1.1方式一
#单个进程 from multiprocessing import Process import time def Text(): print('我是一个子进程') print('我的进程开始了') time.sleep(2) print('我的进程结束了') if __name__ == '__main__': #windows下必须要写这一句,不然会报错 p = Process(target = Text) #实例化产生一个对象 p.start() # 告诉操作系统我要开子进程,告诉完了这行代码就算执行完了,接着往下走,具体操作系统什么时候开子,开多长时间跟你没关系 time.sleep(5) print('我是主进程,我要结束了')
#多个进程 from multiprocessing import Process import time def Text(x): print(f'我是子进程{x}') print(f'{x}的进程开始了') time.sleep(2) print(f'{x}的进程结束了') if __name__ == '__main__': #windows下必须要写这一句,不然会报错 p1 = Process(target = Text,args=('yjy',)) #实例化产生一个对象 子进程1 p2 = Process(target = Text,args=('ypp',)) #实例化产生一个对象 子进程2 p1.start() # 告诉操作系统我要开子进程,告诉完了这行代码就算执行完了,接着往下走,具体操作系统什么时候开子,开多长时间跟你没关系 p2.start() # 告诉操作系统我要开子进程,告诉完了这行代码就算执行完了,接着往下走,具体操作系统什么时候开子,开多长时间跟你没关系 time.sleep(5) print('我是主进程,我要结束了')
1.2 方式二
from multiprocessing import Process import time class Text(Process): #定义一个类,让他继承Process def __init__(self,name): #重写__init__ super().__init__() #继承父类的__init__方法 self.name = name def run(self): #定义一个函数 print(f'子进程的姓名为{self.name},子进程开始') time.sleep(2) print(f'{self.name}进程结束') if __name__ == '__main__': p = Text('yjy') p.start() #通知操作系统子进程开始 print('主进程结束')
二、验证进程的内存空间隔离
from multiprocessing import Process import time x = 0 #定义一个变量x def Check(): global x x = 100 print(f'子进程的x:{x}') if __name__ == '__main__': p = Process(target=Check) p.start() print(f'父进程的x:{x}') ----------------------------------------------------------------------------------- 父进程的x:0 子进程的x:100
父进程的x和子进程的x不是一个值,说明他们两个进程互不影响!
三、僵尸进程与孤儿进程
僵尸进程(有害):当子进程结束的时候,不会将所有内容都释放掉,他会留下自己的pid(类似身份证号码)供父进程来查看,此所谓进程死了没死干净,这就是僵尸进程,他会等待父进程最后把他处理掉
孤儿进程(无害):一个父进程退出,而它的一个或多个子进程还在运行,那么那些子进程将成为孤儿进程。孤儿进程将被init进程(进程号为1)所收养,并由init进程对它们完成状态收集工作。