Python queue

线程安全的queue, 其实现了3种形式的queue,基于不同的写入读出规则

  • FIFO:class queue.Queue(maxsize=0)
  • LIFO(stack):class queue.LifoQueue(maxsize=0)
  • priority queue(优先队列):class queue.PriorityQueue(maxsize=0), 使用内置模块heapq(堆)维护,最小的值最先被取出

在内部,queue使用锁暂时的阻塞竞争的线程,但是其没有被设计为操作可重入性(reentrancy)的线程

拥有两个异常:

  • exception queue.Empty
  • exception queue.Full

class queue.Queue(maxsize=0)对象, FIFO

  • Queue.put(item, block=True, timeout=None): 写入元素
  • Queue.get(block=True, timeout=None): 读取元素
  • Queue.qsize(): 当前queue的大小
  • Queue.empty(): queue是否为空
  • Queue.full(): queue是否已满
  • Queue.put_nowait(item): 与put(item, block=False)等价
  • Queue.get_nowait(): 与get(block=False)等价
In [15]: q2 = queue.Queue(2)                                                    

In [16]: q2.put(1)                                                              

In [17]: q2.put(2)                                                              

In [18]: q2.full()                                                              
Out[18]: True

In [15]: q2 = queue.Queue(2)                                                    

In [16]: q2.put(1)                                                              

In [17]: q2.put(2)                                                              

In [18]: q2.full()                                                              
Out[18]: True

In [19]: q2.qsize()                                                             
Out[19]: 2

In [20]: q2.get()                                                               
Out[20]: 1

In [22]: q2.qsize()                                                             
Out[22]: 1
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值