码迷,mamicode.com
首页 > 编程语言 > 详细

Python中queue消息队列模块

时间:2019-11-01 18:07:50      阅读:101      评论:0      收藏:0      [点我收藏+]

标签:标准   script   ant   优先级   priority   process   imp   evel   先进先出   

from queue import Queue
from queue import PriorityQueue

print("Queue类实现了一个基本的先进先出(FIFO)容器,使用put()将元素添加到序列尾端,get()从队列尾部移除元素。\n")

q = Queue()

for i in range(3):
    q.put(i)

while not q.empty():
    print(q.get())

print("与标准FIFO实现Queue不同的是,LifoQueue使用后进先出序(会关联一个栈数据结构)。\n")

from queue import LifoQueue

q1 = LifoQueue()

for i in range(3):
    q1.put(i)

while not q1.empty():
    print(q1.get())

print("除了按元素入列顺序外,有时需要根据队列中元素的特性来决定元素的处理顺序。例如,老板的打印任务可能比研发的打印任务优先级更高。PriorityQueue依据队列中内容的排序顺序(sort order)来决定那个元素将被检索。")


class Job(object):
    def __init__(self, priority, description):
        self.priority = priority
        self.description = description
        print(New job:, description)
        return

    def __lt__(self, other):
        return self.priority < other.priority


q2 = PriorityQueue()

q2.put(Job(5, Mid-level job))
q2.put(Job(10, Low-level job))
q2.put(Job(1, Important job))  # 数字越小,优先级越高

while not q2.empty():
    next_job = q2.get()  # 可根据优先级取序列
    print(Processing job, next_job.description)

 

Python中queue消息队列模块

标签:标准   script   ant   优先级   priority   process   imp   evel   先进先出   

原文地址:https://www.cnblogs.com/john-xiong/p/11778345.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!