没有合适的资源?快使用搜索试试~ 我知道了~
首页Python高级编程之消息队列(Queue)与进程池(Pool)实例详解
资源详情
资源评论
资源推荐

Python高级编程之消息队列高级编程之消息队列(Queue)与进程池与进程池(Pool)实例详解实例详解
主要介绍了Python高级编程之消息队列(Queue)与进程池(Pool),结合实例形式详细分析了Python消息队列与进程
池的相关原理、使用技巧与操作注意事项,需要的朋友可以参考下
本文实例讲述了Python高级编程之消息队列(Queue)与进程池(Pool)。分享给大家供大家参考,具体如下:
Queue消息队列消息队列
1.创建创建
import multiprocessing
queue = multiprocessing.Queue(队列长度)
2.方法方法
方法方法 描述描述
put
变量名.put(数据),放入数据(如队列已满,则程序进入阻塞状态,等待队列取出后
再放入)
put_nowait
变量名.put_nowati(数据),放入数据(如队列已满,则不等待队列信息取出后再放
入,直接报错)
get
变量名.get(数据),取出数据(如队列为空,则程序进入阻塞状态,等待队列防如数
据后再取出)
get_nowait
变量名.get_nowait(数据),取出数据(如队列为空,则不等待队列放入信息后取出数
据,直接报错),放入数据后立马判断是否为空有时为True,原因是放入值和判断
同时进行
qsize 变量名.qsize(),消息数量
empty 变量名.empty()(返回值为True或False),判断是否为空
full 变量名.full()(返回值为True或False),判断是否为满
3.进程通信进程通信
因为进程间不共享全局变量,所以使用Queue进行数据通信,可以在父进程中创建两个字进程,一个往Queue里写数据,一个
从Queue里取出数据。
例:
import multiprocessing
import time
def write_queue(queue):
# 循环写入数据
for i in range(10):
if queue.full():
print("队列已满!")
break
# 向队列中放入消息
queue.put(i)
print(i)
time.sleep(0.5)
def read_queue(queue):
# 循环读取队列消息
while True:
# 队列为空,停止读取
if queue.empty():
print("---队列已空---")
break
# 读取消息并输出
result = queue.get()
print(result)
if __name__ == '__main__':
# 创建消息队列
queue = multiprocessing.Queue(3)
# 创建子进程
p1 = multiprocessing.Process(target=write_queue, args=(queue,))
p1.start()
# 等待p1写数据进程执行结束后,再往下执行
p1.join()
p1 = multiprocessing.Process(target=read_queue, args=(queue,))
p1.start()
执行结果:



















安全验证
文档复制为VIP权益,开通VIP直接复制

评论0