多线程之线程queue

大城市里の小女人 提交于 2020-02-11 22:39:51

有三种不同的用法

class queue.Queue(maxsize=0) #队列:先进先出

 

按 Ctrl+C 复制代码
按 Ctrl+C 复制代码

class queue.LifoQueue(maxsize=0) #堆栈:last in fisrt out

复制代码
import queue

q=queue.LifoQueue()
q.put('first')
q.put('second')
q.put('third')

print(q.get())
print(q.get())
print(q.get())



'''
结果(后进先出):
third
second
first
'''
复制代码

class queue.PriorityQueue(maxsize=0) #优先级队列:存储数据时可设置优先级的队列

复制代码
import queue

q=queue.PriorityQueue()
#put进入一个元组,元组的第一个元素是优先级(通常是数字,也可以是非数字之间的比较),数字越小优先级越高
q.put((20,'a'))
q.put((10,'b'))
q.put((30,'c'))

print(q.get())
print(q.get())
print(q.get())



'''
结果(数字越小优先级越高,优先级高的优先出队):
(10, 'b')
(20, 'a')
(30, 'c')
'''
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!