(17)线程队列---queue LifoQueue PriorityQueue

线程常用队列有: queue LifoQueue PriorityQueue

语法: 大致和进程队列语法一致

put 往队列当中放值,超过队列长度,直接加阻塞

get 如果获取不到加阻塞

put_nowait 如果放入的超过了队列长度,直接报异常错误

get_nowait 如果获取到直接报异常错误

(1) queue 先进先出

# 第一种写法:

from queue import Queue

# q = Queue()

#第二种写法:

import queue

q = queue.Queue()

q.put(1)

q.put(2)

print(q.get()) # 1

(2)LifoQueue 后进先出

from queue import LifoQueue

lq = LifoQueue()

lq.put(1)

lq.put(2)

lq.put('aaa')

print(lq.get()) # aaa

(3)PriorityQueue 按照优先级排序

#1.放入元组,先按照前面数字进行排列,如果数字相同,再按照ascii吗从小到大排序

from queue import PriorityQueue

pq = PriorityQueue()

pq.put((13, 'abc'))

pq.put((5, "ccc"))

pq.put((5, "bcc"))

pq.put((15, "bbb"))

print(pq.get()) # (5, 'bcc')

print(pq.get()) # (5, 'ccc')

print(pq.get()) # (13, 'abc')

print(pq.get()) # (15, 'bbb')

(4) 单独一个元素的,只能是都放同一种类型

pq = PriorityQueue()

pq.put(15)

pq.put(13)

pq.put(3)

# pq.put("3434") 报错

print(pq.get())

print(pq.get())

print(pq.get())

# print(pq.get())

 

 

 

 

 

 

 

 

 

 

 

 

 

 

转载于:https://www.cnblogs.com/lyj910313/p/10787368.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值