亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

Python -- 多進程

標簽:
Python

进程通信

方式一、共享内存(进程安全,效率高)

共享变量:multiprocessing.Value
共享数组:multiprocessing.Array
 

方式二、Manager对象:

Mananger 包括:list, dict, Namespace, Lock, RLock, Semaphore, BoundedSemaphore, Condition, Event, Queue, Value, Array
Manager对象,相对于共享内存,更加灵活,支持Python对象,可以通过网络进行共享,但是效率低
 

进程同步

Manager对象:Lock, RLock, Semaphore, BoundedSemaphore, Condition, Event
1、简单同步机制锁 Lock、RLock(A/B 进程同时修改一个对象,RLock支持嵌套)
2、可控制进程数量 Semaphore, BoundedSemaphore (例如连接池限制)
3、复杂同步条件变量 Condition (A/B进程可以多条件判断,交替执行)
4、事件控制 Event(A、C进程等待B进程执行某种操作之后才能执行)
 

进程池

multiprocessing.Poolres = pool.apply_async (非阻塞)res = pool.apply (阻塞)res.get(timeout=2) 获取执行return的结果

 

subprocess(经常用来执行Linux命令,非常方便)

cmds = [‘ls’, ‘-l’]subprocess.call(cmds, stdout=fd, stderr=fd)返回执行后状态码subprocess.check_call(cmds, stdout=fd, stderr=fd)执行成功返回0,失败抛出异常subprocess.call_output(cmds, stderr=fd)执行成功返回标准输出,失败抛出异常都是阻塞执行命令,标准与错误输出到文件句柄或者PIPE

 

多进程注意点:

1、不能使用Lock嵌套,会导致死锁,应该使用RLock嵌套
2、多线程/进程,随时可能发生切换,操作相同变量要加锁
3、多进程普通类型共享,可以使用共享内存Value,Array,效率高

點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消