import os
import time
from multiprocessing import Process
global_num=100 #全局变量
def func (name,age):
print('子进程name,age:',name,age)
print('子进程ID:',os.getpid())
global global_num
global_num=0
print('子进程global:',global_num)
class myProcess(Process):
def __init__(self,name,age):
super().__init__()
self.name=name
self.age=age
def run(self):#start最后调用run方法
print('子进程id',os.getpid())
if __name__ == '__main__':
p1=Process(target=func,args=('chuxi',18))#创建进程的第一种方法,传值的第一种方法
p1.start()
p1.join() # 主进程等待p1子进程运行完在运行,阻塞
print('p1子进程的id:',p1.pid)
p2 = Process(target=func, kwargs={'name': 'chuxi', 'age': 18})#传值的第二种方法
p2.start()
print('主进程的global_num:',global_num)#证明进程之间数据隔离
p2.terminate()#p2进程像操作系统发出关闭指令
time.sleep(1)
print('p2进程是否还存在:',p2.is_alive())
#可以主进程有input,子进程不可以有
lst=[]
for i in range(10):
p4 = Process(target=func, args=('hah', 18))
p4.start()
lst.append(p4)
for el in lst:
el.join()
p3 = myProcess('chuxi', 18)#创建进程的第二种方法
#需要强调的是,p.join只能join住start开启的进程,而不能join住run开启的进程
p3.daemon = True # 把p3进程设置为主进程的守护进程,主程序结束他就跟着结束
p3.start()