线程队列基础

from queue import Queue#先进先出队列
from queue import PriorityQueue#继承了先进先出队列
from queue import LifoQueue#后进先出
#创建一个线程队列
q=Queue(3)
#放数据
q.put(“q1”)
q.put(“q2”)
q.put(“q3”)
print(q.full())
print(q.empty())

#取数据
q.get()#q1
q.get()#q2
q.get()#q3
print(q.empty())#True

#阻塞

#队列的优先级
pq=PriorityQueue()
#任务不要直接put,需要封装到元祖当中
#格式:(数字,消息),数字越小,优先级越高,
pq.put((1,‘King’,))
pq.put((0,‘Quen’,))
pq.put((2,‘Jack’,))
pq.put((-1,‘people’,))
print(pq.get())#-1的消息,先输出
i=0
while i<pq.qsize():
print(pq.get())
“”"
(-1, ‘people’)
(0, ‘Quen’)
(1, ‘King’)
(2, ‘Jack’)
“”"

#后进先出队列
lq=LifoQueue()
lq.put(“d1”)
lq.put(“d2”)
lq.put(“d3”)
print(lq.get())
print(lq.get())
print(lq.get())

猜你喜欢

转载自blog.csdn.net/chengchuanji/article/details/88560701
今日推荐