python的queue队列类型及函数

1 队列的种类

  1. Python queue模块的FIFO队列先进先出。 class queue.Queue(maxsize)
  2. LIFO类似于堆,即先进后出。 class queue.LifoQueue(maxsize)
  3. 还有一种是优先级队列级别越低越先出来。 class queue.PriorityQueue(maxsize)
import queue

# 先进先出队列
queue_obj = queue.Queue()

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

for i in range(3):
    print(queue_obj.get())

"""执行结果
0
1
2
"""

# 先进后出队列,类似于堆栈
queue_obj = queue.LifoQueue()

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

for i in range(3):
    print(queue_obj.get())

"""执行结果
2
1
0
"""

# 优先级队列
import Queue
import threading

class Job(object):
    def __init__(self, priority, description):
        self.priority = priority
        self.description = description
        print 'Job:',description
        return
    def __cmp__(self, other):
        return cmp(self.priority, other.priority)

q = Queue.PriorityQueue()

q.put(Job(3, 'level 3 job'))
q.put(Job(10, 'level 10 job'))
q.put(Job(1, 'level 1 job'))

def process_job(q):
    while True:
        next_job = q.get()
        print 'for:', next_job.description
        q.task_done()

workers = [threading.Thread(target=process_job, args=(q,)),
        threading.Thread(target=process_job, args=(q,))
        ]

for w in workers:
    w.setDaemon(True)
    w.start()

q.join()

2 队列函数

maxsize = 10
queue_obj = queue.Queue(maxsize)  # maxsize 代表队列的上限, 如果队列已满, 则插入时需要等待, maxsize为零或负数时.队列没有限制

queue_obj.get(block=True, timeout=None)  # block为True时,表示等待获取,直至timeout超时
queue_obj.get_nowait()  # 当获取不到元素时,报错

queue_obj.put(item="待插入的元素", block=True, timeout=None)  # block为True时,表示等待插入,直至timeout超时
queue_obj.put_nowait('待插入的元素')  # 当不能插入元素时报错

queue_obj.empty()  # 队列为空时,返回True

queue_obj.full()  # 如果队列满时,返回True

queue_obj.task_done()  # 在每次获取队列中的元素, 操作完成之后, 调用该函数告诉队列我已经使用完成, 主要是给join函数使用
queue_obj.join()  # 等待队列内的元素全部被获取后, 再接触阻塞(直至所有的任务全部task_done)

"""下面的例子验证toask_done和join的关系"""
for i in range(3):
    queue_obj.put(i)  # 这里像队列中添加三个元素

queue_obj.get()  # 这里获取队列中的消息
queue_obj.task_done()

queue_obj.get()  # 这里获取队列中的消息
queue_obj.task_done()

queue_obj.get()  # 这里获取队列中的消息
queue_obj.task_done()

queue_obj.join()
print('直至队列中的所有元素全部都被取出, join函数才不会阻塞, 如果只执行了两次task_done函数, 则join会一直阻塞')
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python Queue模块是用来在线程间进行数据交换的常用模块。它包含了一些常用的队列操作函数,如创建队列对象、添加数据到队列、从队列取值等。 在Python,可以使用Queue模块来创建一个队列对象,并通过put()函数队列添加数据,通过get()函数队列取值。在多线程的情况下,可以使用队列来实现生产者-消费者模型,即一个线程往队列添加数据,另外的线程从队列取值。 队列模块提供了多种类型队列,如FIFO(先进先出)队列和LIFO(后进先出)队列。可以通过参数maxsize来限制队列的长度,如果maxsize小于1表示队列长度无限制。另外,队列模块还提供了一些其他的函数,如返回队列大小、判断队列是否为空、判断队列是否已满等。 使用Queue模块可以方便地实现一些需求,比如爬虫的请求地址,可以将需要请求的URL放入队列,然后通过多线程从队列取值并进行请求。 总结起来,Python Queue模块是用来在线程间进行数据交换的模块,提供了创建队列对象、添加数据到队列、从队列取值等常用的队列操作函数。可以通过队列模块实现生产者-消费者模型,并且支持不同类型队列,如FIFO队列和LIFO队列。使用队列模块可以方便地实现一些需求,如爬虫的请求地址。<span class="em">1</span><span class="em">2</span><span class="em">3</span><span class="em">4</span>

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值