python3 的 queue模块

本文深入讲解了三种队列类型:先进先出队列、优先级队列和堆栈的使用方法及特性。包括队列的基本操作如put和get,以及特殊方法如qsize和empty。适合初学者和开发者快速掌握队列的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、队列,先进先出(queue.Queue())
from queue import Queue
q = Queue(3) #指定队列的大小
q.put(1)
q.put(2)
q.put(3)
q.get()------>1, 2, 3
方法:
q.qsize()返回队列的大小
q.empty()如果队列为空,返回True
q.full()如果队列满了,返回True
q.get([block[, tmeout]]) 从队列中取出一个元素
q.put(item, timeout) 放入队列中一个元素
q.get_nowait()相当于q.get(False)
q.put_nowait()相当于q.put(False)
q.join()阻塞调用线程,直到队列中的所有任务被处理掉, 等队列为空在执行其他的任务
q.task_done()在完成一项工作后,函数向已完成的队列发送一个信号

二、基于优先级的队列(PriorityQueue)
from queue import PriorityQueue
q = PriorityQueue(3) 指定队列大小
q.put(1, ‘a’)
q.put(2, ‘d’)
q.put(-1, ‘s’)
q.get()------>s, a, d
使用数字表示优先级,数字越小优先级就越高,就先取出来

三、堆栈,后进先出
from queue import LifoQueue
q = LifoQueue(3) 指定堆栈大小
q.put(1)
q.put(2)
q.put(3)
q.get()----->3,2,1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值