Python的并发并行[2] -> 队列[0] -> queue 模块
queue 模块 / queue Module
1 常量 / Constants
Pass
2 函数 / Function
Pass
3 类 / Class
3.1 Queue类
类实例化:queue = queue.Queue(maxsize=0)
类的功能:用于生成一个先入先出队列实例
传入参数: maxsize
maxsize: int类型,队列的最大值,无空间时阻塞,未指定时为无限队列
返回参数: queue
queue: instance类型,生成的先入先出队列实例
3.1.1 put()方法
函数调用: queue.put(item, block=True, timeout=None)
函数功能:将item放进队列中
传入参数: item, block, timeout
item: int/str/obj等类型,放进队列中的项目
block: bool类型,设置阻塞,True则阻塞,False则会引发异常
timeout: None/int类型,设置阻塞超时时间(s),None则无限时阻塞
返回参数: 无
3.1.2 get()方法
函数调用: item = queue.get(block=True, timeout=None)
函数功能:将item从队列中取出
传入参数: block, timeout
block: bool类型,设置阻塞,True则阻塞,False则会引发异常
timeout: None/int类型,设置阻塞超时时间(s),None则无限时阻塞
返回参数: item
item: int/str/obj等类型,从队列中取出的项目
3.1.3 put_nowait()方法
函数调用: queue.put_nowait(item)
函数功能:无等待将item放进队列中,相当于put(item, False),失败则引发Full异常
传入参数: item
item: int/str/obj等类型,放进队列中的项目
返回参数: 无
3.1.4 get_nowait()方法
函数调用: item = queue.get_nowait()
函数功能:无等待将item从队列中取出,相当于get(False),失败则引发Empty异常
传入参数: 无
返回参数: item
item: int/str/obj等类型,队列中取出的项目
3.1.5 task_done()方法
函数调用: queue.task_done()
函数功能: 用于表明一个任务已经完成,设置完成标志,常用于队列的消耗线程,每一个get()函数取出一个item,随后可以设置一个task_done,当所有队列的任务都标记完成后,join将释放阻塞
传入参数: 无
返回参数: 无
3.1.6 join ()方法
函数调用: queue.join()
函数功能:用于阻塞当前的线程,等待join之前所有的队列(包括join之前入列并出列的任务)任务都设置了task_done标志后,才会解除阻塞
传入参数: 无
返回参数: 无
3.1.7 qsize()方法
函数调用: size = queue.qsize()
函数功能:返回当前队列的大小(由于其他线程存在修改,该值并不准确,为近似值)
传入参数: 无
返回参数: size
siez: int类型,队列中item的数量
3.1.8 empty()方法
函数调用: status = queue.empty()
函数功能:返回当前队列的状态,为空返回True,否则返回False,与qsize一样,返回的是一个近似值,若需要等待所有队列结束,建议使用join()函数
传入参数: 无
返回参数: status
status: bool类型,True表示当前队列为空
3.1.9 full()方法
函数调用: status = queue.full()
函数功能:返回当前队列的状态,队列已满返回True,否则返回False,同样返回的是一个近似值
传入参数: 无
返回参数: status
status: bool类型,True表示当前队列为空
3.2 LifoQueue类
类实例化:queue = queue.LifoQueue(maxsize=0)
类的功能:用于生成一个后入先出队列实例
传入参数: maxsize
maxsize: int类型,队列的最大值,无空间时阻塞,未指定时为无限队列
返回参数: queue
queue: instance类型,生成的后入先出队列实例
Note:
对于LifoQueue类,其基类是Queue,在源代码中重定义了Queue的_init, _qsize, _put, _get函数,使其在队列的处理顺序上有所不同(其本质为向队列列表中取出item时_get()函数使用的是popleft函数还是pop函数),其父类的函数均可以继承使用。
3.3 PriorityQueue类
类实例化:queue = queue.PriorityQueue(maxsize=0)
类的功能:用于生成一个优先级队列实例,最小的最优取出
传入参数: maxsize
maxsize: int 类型,队列的最大值,无空间时阻塞,未指定时为无限队列
返回参数: queue
queue: instance类型,生成的优先级队列实例
Note:
对于PriorityQueue类,其基类也是Queue,同样在源代码中重定义了Queue的_init, _qsize, _put, _get函数,使其在队列的处理顺序上有所不同(其本质为向队列列表中取出item时_get()使用了heappop函数,而放入时使用了heappush函数),父类函数同样可继承使用。
3.4 Empty异常类
类实例化:无
类的功能:用于当队列为空且调用get*()方法时抛出的异常
传入参数: 无
返回参数: 无
3.5 Full异常类
类实例化:无
类的功能:用于当队列已满且调用put*()方法时抛出的异常
传入参数: 无
返回参数: 无
Python的并发并行[2] -> 队列[0] -> queue 模块的更多相关文章
- Python的并发并行[3] -> 进程[0] -> subprocess 模块
subprocess 模块 0 模块描述 / Module Description From subprocess module: """Subprocesses wit ...
- Python的并发并行[1] -> 线程[0] -> threading 模块
threading模块 / threading Module 1 常量 / Constants Pass 2 函数 / Function 2.1 setprofile()函数 函数调用: thread ...
- Python的并发并行[2] -> 队列[1] -> 使用队列进行任务控制
使用队列进行任务控制 1 FIFO与LIFO队列 FIFO(First In First Out)与LIFO(Last In First Out)分别是两种队列形式,在FIFO中,满足先入先出的队列方 ...
- day43-python消息队列二-queue模块
Python提供了Queue模块来专门实现消息队列Queue对象 Queue对象实现一个fifo队列(其他的还有lifo.priority队列,这里不再介绍).queue只有maxsize一个构造参数 ...
- Python的并发并行[0] -> 基本概念
基本概念 / Basic Concept 快速跳转 进程 / Process 线程 / Thread 协程 / Coroutine 全局解释器锁 / Global Interpreter Lock ...
- Python的并发并行[4] -> 并发[0] -> 利用线程池启动线程
利用线程池启动线程 submit与map启动线程 利用两种方式分别启动线程,同时利用with上下文管理来对线程池进行控制 from concurrent.futures import ThreadPo ...
- Python的并发并行[1] -> 线程[1] -> 多线程的建立与使用
多线程的建立与使用 目录 生成线程的三种方法 单线程与多线程对比 守护线程的设置 1 生成线程的三种方法 三种方式分别为: 创建一个Thread实例,传给它一个函数 创建一个Thread实例,传给它一 ...
- Python的并发并行[1] -> 线程[2] -> 锁与信号量
锁与信号量 目录 添加线程锁 锁的本质 互斥锁与可重入锁 死锁的产生 锁的上下文管理 信号量与有界信号量 1 添加线程锁 由于多线程对资源的抢占顺序不同,可能会产生冲突,通过添加线程锁来对共有资源进行 ...
- Python的并发并行[1] -> 线程[3] -> 多线程的同步控制
多线程的控制方式 目录 唤醒单个线程等待 唤醒多个线程等待 条件函数等待 事件触发标志 函数延迟启动 设置线程障碍 1 唤醒单个线程等待 Condition类相当于一把高级的锁,可以进行一些复杂的线程 ...
随机推荐
- 《Cracking the Coding Interview》——第11章:排序和搜索——题目4
2014-03-21 21:28 题目:给定一个20GB大小的文本文件,每一行都是一个字符串.请设计方法将这个文件里的字符串排序. 解法:请看下面的注释. 代码: // 11.4 Given a fi ...
- chromedriver版本支持的Chrome版本
下载chromedriver,链接:http://chromedriver.storage.googleapis.com/index.html chromedirver版本 支持的Chrome版本 ...
- (原) Unreal搬山-引言(图多慎)
@author:白袍小道 扯淡:(图多) 何为搬山,这里借了剑来少年郎一句.(若有同道中人,甚是开心,开心的很) 江湖岂能没前辈) (江湖很大,足够你浪) (刺客信条 \荒野 \神秘海域 \死亡空间 ...
- try-catch-finally容易犯的错误
测试环境 JDK1.8 1. catch中包含return //有return的时候 输出13423 //无return的时候 输出134234 public class Trycatch { pub ...
- install ironic-inspector
安装相应的包和组件 yum install openstack-ironic-inspector python-ironic-inspector-client -y 创建user openstack ...
- Hadoop平台K-Means聚类算法分布式实现+MapReduce通俗讲解
Hadoop平台K-Means聚类算法分布式实现+MapReduce通俗讲解 在Hadoop分布式环境下实现K-Means聚类算法的伪代码如下: 输入:参数0--存储样本数据的文本文件inpu ...
- Python数据分析-Matplotlib图标绘制
Matplotlib介绍 Matplotlib是一个强大的Python绘图和数据可视化的工具包. Matplotlib的主要功能 Matplotlib是python中的一个包,主要用于绘制2D图形(当 ...
- NAT64与DNS64基本原理概述
NAT64与DNS64基本原理概述 1.NAT64与DNS64背景 在IPv6网络的发展过程中,面临最大的问题应该是IPv6与IPv4的不兼容性,因此无法实现二种不兼容网络之间的互访.为了实现 ...
- [洛谷P1501][国家集训队]Tree II
题目大意:给一棵树,有四种操作: $+\;u\;v\;c:$将路径$u->v$区间加$c$ $-\;u_1\;v_1\;u_2\;v_2:$将边$u_1-v_1$切断,改成边$u_2-v_2$, ...
- 绑定域名到 GitHub Pages
简介 我在阿里云上注册了一个新域名:yuanzb.com,我已经在GitHub Pages上建立了自己的博客:http://yuanzb.github.io/yuanzb/.现在我希望将yuanzb. ...