Python进程间通信Queue

1.Queue使用方法:

  • Queue.qsize():返回当前队列包含的消息数量;
  • Queue.empty():如果队列为空,返回True,反之False ;
  • Queue.full():如果队列满了,返回True,反之False;
  • Queue.get():获取队列中的一条消息,然后将其从列队中移除,可传参超时时长。
  • Queue.get_nowait():相当Queue.get(False),取不到值时触发异常:Empty;
  • Queue.put():将一个值添加进数列,可传参超时时长。
  • Queue.put_nowait():相当于Queue.get(False),当队列满了时报错:Full。

2.Queue使用实例:

来,上代码:

#!/usr/bin/env python3

import time
from multiprocessing import Process,Queue q = Queue() #创建列队,不传数字表示列队不限数量
for i in range(11):
q.put(i) def A():
while 1:
try:
num = q.get_nowait()
print('我是进程A,取出数字:%d'%num)
time.sleep(1)
except :
break def B():
while 1:
try:
num = q.get_nowait()
print('我是进程B,取出数字:%d'%num)
time.sleep(1)
except :
break p1 = Process(target = A)
p2 = Process(target = B)
p1.start()
p2.start()

此程序是在队列中加入10个数字,然后用2个进程来取出。

运行结果:

我是进程A,取出数字:0
我是进程B,取出数字:1
我是进程A,取出数字:2
我是进程B,取出数字:3
我是进程A,取出数字:4
我是进程B,取出数字:5
我是进程B,取出数字:6
我是进程A,取出数字:7
我是进程B,取出数字:8
我是进程A,取出数字:9
我是进程B,取出数字:10

3.使用进程池Pool时,Queue会出错,需要使用Manager.Queue:

上代码

#!/usr/bin/env python3

import time
from multiprocessing import Pool,Manager,Queue q = Manager().Queue()
for i in range(11):
q.put(i) def A(i):
num = q.get_nowait()
print('我是进程%d,取出数字:%d'%(i,num))
time.sleep(1) pool = Pool(3) for i in range(10):
pool.apply_async(A,(i,)) pool.close()
pool.join()

运行结果:

我是进程1,取出数字:0
我是进程0,取出数字:1
我是进程2,取出数字:2
我是进程4,取出数字:3
我是进程3,取出数字:4
我是进程5,取出数字:5
我是进程6,取出数字:6
我是进程7,取出数字:7
我是进程8,取出数字:8
我是进程9,取出数字:9
  • 当把Manager().Queue()直接换成Queue(),可能会出现资源混乱,缺少进程。

最新文章

  1. python基础之初始python
  2. Android开源项目大全之工具库
  3. WF4 持久化 <第四篇>
  4. iOS中使用自定义字体
  5. I.MX6 git patch
  6. 某deed笔试题
  7. React+Immutable.js的心路历程
  8. css单位和值
  9. HTTP协议&SOCKET协议
  10. Flask 学习 六 大型程序结构
  11. Python的单向链表实现
  12. vue.js初始学习笔记&vue-cli
  13. SpringMVC使用HttpInvoker发布远程服务
  14. 查找->动态查找表->B+树(无代码)
  15. 黄聪:3分钟学会sessionStorage用法
  16. Android与Unity相互调用
  17. final 评论 II
  18. Linux 下安装 java 环境(jdk + mysql + tomcat)
  19. 【[SCOI2010]生成字符串】
  20. 【题解】HAOI2008木棍分割

热门文章

  1. bzoj 1132 [POI2008]Tro 几何
  2. Linux查看内核和系统版本
  3. Spring @Async的异常处理
  4. 表单元素(form、文本、按钮、选择)
  5. UIImageView与UIScrollView的关系图
  6. 阿里云服务器下安装配置 vsftpd —— 基于CentOS 6.3 【简洁版】
  7. 【转】ps命令详解
  8. Python参数输入模块-optparse
  9. netlink socket编程
  10. 函数导出在kvm_intel.ko,kvm.ko不共享