Python并发编程:多进程-队列

队列介绍

  进程彼此之间互相隔离,要实现进程间通信(IPC),multiprocessing模块支持两种形式:队列和管道,这两种方式都是使用消息传递的

创建队列的类(底层就是以管道和锁定的方式实现)

1

Queue(maxsize):创建共享的进程队列,Queue是多进程安全的队列,可以使用Queue实现多进程之间的数据传递

  参数介绍

1

2

3

4

maxsize是队列中允许最大项数,省略则无大小限制

但需要明确:

    1、队列内存放的是消息而非大数据

    2、队列占用的是内存空间,因而maxsize即便是无大小限制也受限于内存大小

  主要方法介绍

1

2

q.put方法用以插入数据到队列中

q.get方法可以从队列读取并且删除一个元素

  队列的使用

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

from multiprocessing import Queue

= Queue(3)

q.put(1)

q.put(2)

q.put(3)

print(q.full())     # 满了

# q.put(4)  # 再放就阻塞住了

print(q.get())

print(q.get())

print(q.get())

print(q.empty())    # 空了

print(q.get())  # 再取就阻塞住了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值