目录python
仔细说来,multiprocess不是一个模块而是python中一个操做、管理进程的包。 之因此叫multi是取自multiple的多功能的意思,在这个包中几乎包含了和进程有关的全部子模块。因为提供的子模块很是多,为了方便你们归类记忆,我将这部分大体分为四个部分:建立进程部分,进程同步部分,进程池部分,进程之间数据共享。linux
process模块是一个建立进程的模块,借助这个模块,就能够完成进程的建立。windows
Process([group [, target [, name [, args [, kwargs]]]]])
,由该类实例化获得的对象,表示一个子进程中的任务(还没有启动)安全
强调:网络
参数介绍:app
args=(1,2,'egon',)
kwargs={'name':'egon','age':18}
p.start()
:启动进程,并调用该子进程中的p.run()p.run()
:进程启动时运行的方法,正是它去调用target指定的函数,咱们自定义类的类中必定要实现该方法p.terminate()
:强制终止进程p,不会进行任何清理操做,若是p建立了子进程,该子进程就成了僵尸进程,使用该方法须要特别当心这种状况。若是p还保存了一个锁那么也将不会被释放,进而致使死锁p.is_alive()
:若是p仍然运行,返回Truep.join([timeout])
:主线程等待p终止(强调:是主线程处于等的状态,而p是处于运行的状态)。timeout是可选的超时时间,须要强调的是,p.join只能join住start开启的进程,而不能join住run开启的进程p.daemon
:默认值为False,若是设为True,表明p为后台运行的守护进程,当p的父进程终止时,p也随之终止,而且设定为True后,p不能建立本身的新进程,必须在p.start()
以前设置p.name
:进程的名称p.pid
:进程的pidp.exitcode
:进程在运行时为None、若是为–N,表示被信号N结束(了解便可)p.authkey
:进程的身份验证键,默认是由os.urandom()
随机生成的32字符的字符串。这个键的用途是为涉及网络链接的底层进程间通讯提供安全性,这类链接只有在具备相同的身份验证键时才能成功(了解便可)在Windows操做系统中因为没有fork(linux操做系统中建立进程的机制),在建立子进程的时候会自动 import 启动它的这个文件,而在 import 的时候又执行了整个文件。所以若是将process()直接写在文件中就会无限递归建立子进程报错。因此必须把建立子进程的部分使用if __name__ =='__main__ 判断保护起来,import 的时候,就不会递归运行了。dom
内部会调用wait(),等待执行完毕,回收pid函数
from multiprocessing import Process import time def foo(): print('process start') time.sleep(2) print('process end') if __name__ == '__main__': p = Process(target=foo) #建立子进程 p.start()#给操做系统发指令,开启子进程 time.sleep(5) p.join()#阻塞住主进程再等待子进程结束,而后再往下执行,(了解的是:内部会待用wait()) print('主进程') # process start process end 主进程
from multiprocessing import Process import time def foo(x): print('Process start') time.sleep(x) print('Process end') if __name__ == '__main__': p1 = Process(target=foo,args=(1,)) #进程传参的固定模式 p2 = Process(target=foo,args=(2,)) p3 = Process(target=foo,args=(3,)) start = time.time() p1.start() p2.start() p3.start() p1.join() p2.join() p3.join() end = time.time() print(end-start) print('主进程') #进程是同时开启的,不肯定是哪个先开启,而且建立子进程须要时间,所以是3秒多 Process start Process start Process start Process end Process end Process end 3.136319160461426 主进程
join用法2,优化优化
from multiprocessing import Process import time def foo(x): print(f'process{x},start') time.sleep(x) print(f'process{x},end') if __name__ == '__main__': strart = time.time() p_list = [] for i in range(1,4): p=Process(target=foo,args=(i,)) p.start() p_list.append(p) print(p_list) for p in p_list: p.join() end = time.time() print(end-strart) print('主进程') # [<Process(Process-1, started)>, <Process(Process-2, started)>, <Process(Process-3, started)>] process1,start process2,start process3,start process1,end process2,end process3,end 3.1335043907165527 主进程
from multiprocessing import Process import time def foo(x): print(f'process{x},start') time.sleep(x) print(f'process{x},end') if __name__ == '__main__': p1 = Process(target=foo,args=(1,)) p2 = Process(target=foo,args=(2,)) p3 = Process(target=foo,args=(3,)) start = time.time() p1.start() p1.join() p2.start() p2.join() p3.start() p3.join() end = time.time() print(end-start) print('主进程结束') #因为每个进程都是在执行完后才会执行下一个进程,所以,时间是多余6s,建立子进程空间是须要时间的 process1,start process1,end process2,start process2,end process3,start process3,end 6.339004039764404 主进程结束
进程的pid,至关于人的id身份证同样操作系统
from multiprocessing import Process,current_process import os import time def task(): print('子进程 start') print('在子进程中查询本身的pid>',current_process().pid) print('在子进程中查询父进程的pid>',os.getppid()) time.sleep(200) print('子进程end') if __name__ == '__main__': p = Process(target=task) p.start() print('在主进程中查看子进程的pid>',p.pid)#必定要写在start以后,在给操做系统发送开启子进程以后 print('主进程的pid>',os.getpid()) print('主进程的父进程的pid>',os.getppid()) print('主进程') ### 在主进程中查看子进程的pid> 11112 主进程的pid> 7320 主进程的父进程的pid> 2464 主进程 子进程 start 在子进程中查询本身的pid> 11112 在子进程中查询父进程的pid> 7320
from multiprocessing import Process,current_process import time def foo(): print('process start') print('子进程的名字',current_process().name) time.sleep(2) print('process end') if __name__ == '__main__': p = Process(target=foo) p2 = Process(target=foo) p3 = Process(target=foo,name='ocean') p.start() p2.start() p3.start() print(p.name) print(p2.name) print(p3.name) print('主进程') ################ Process-1 Process-2 ocean 主进程 process start 子进程的名字 Process-1 process start 子进程的名字 Process-2 process start 子进程的名字 ocean process end process end process end
from multiprocessing import Process import time def foo(): print('process start') time.sleep(2) print('process end') if __name__ == '__main__': p = Process(target=foo) p.start() print(p.is_alive())#True,进程开启,进程或者 time.sleep(5) print(p.is_alive())#False 代码运行完毕,进程死亡(系统断定,实际状况在具体分析) print('主进程') ############## True process start process end False 主进程
from multiprocessing import Process import time def foo(): print('process start') time.sleep(10) print('process end') if __name__ == '__main__': p = Process(target=foo) p.start() p.terminate()#给操做系统发送一个请求,杀死进程的请求 print(p.is_alive()) p.join() print(p.is_alive()) print('主进程') ############### True False 主进程
import os from multiprocessing import Process class MyProcess(Process): def __init__(self,name): # super(MyProcess,self).__init__() super().__init__() self.name=name def run(self): print(os.getpid()) print('%s 正在和女主播聊天' %self.name) if __name__ == '__main__': p1=MyProcess('wupeiqi') p2=MyProcess('yuanhao') p3=MyProcess('nezha') p1.start() # start会自动调用run p2.start() # p2.run() p3.start() p1.join() p2.join() p3.join() print('主线程') #################### 1516 wupeiqi 正在和女主播聊天 4864 yuanhao 正在和女主播聊天 18228 nezha 正在和女主播聊天 主线程
from multiprocessing import Process def work(): global n n = 0 print('子进程内:',n) if __name__ == '__main__': n = 100 p = Process(target=work) p.start() print('主进程内:',n) ############## 主进程内: 100 子进程内: 0