|
|
马上注册,结交更多好友,享用更多功能,让你轻松玩转新大榭论坛!
您需要 登录 才可以下载或查看,没有账号?注册
x
Python Queue 模块详解
. V: h, D/ P+ x5 sPython3中队列是线程间最常用的交换数据的形式。Queue模块python3内置的标准模块,是提供队列操作的模块,虽然简单易用,但是不小心的话,还是会出现一些意外。 创建一个“队列”对象# l* m) h) ]" t- w/ x
import queue4 m1 S2 i: b, L
q = queue.queue(maxsize = 10)% e1 e ]) N. Q9 a ?- V
queue.queue类即是一个队列的同步实现。队列长度可为无限或者有限。可通过queue的构造函数的可选参数maxsize来设定队列长度。如果maxsize小于1就表示队列长度无限。 将一个值放入队列中- ?3 P2 r2 d& z. P0 B) Y! {
q.put(10)+ V) @$ R& d4 |' Z2 Q8 @/ _
调用队列对象的put()方法在队尾插入一个项目。put()有两个参数,第一个item为必需的,为插入项目的值;第二个block为可选参数,默认为- \- Y+ _8 S$ X& {0 Y) {& j
1。如果队列当前为空且block为1,put()方法就使调用线程暂停,直到空出一个数据单元。如果block为0,put方法将引发Full异常。 将一个值从队列中取出
. \! x9 p* o* w8 \& O6 s4 Nq.get(). c5 H& X3 k3 i5 [) P
调用队列对象的get()方法从队头删除并返回一个项目。可选参数为block,默认为True。如果队列为空且block为True,get()就使调用线程暂停,直至有项目可用。如果队列为空且block为False,队列将引发Empty异常。 Python queue模块有三种队列及构造函数:" ^2 b+ H h& _2 z' ?, v" w, v
1、Python queue模块的FIFO队列先进先出。 class queue.queue(maxsize)
- ^+ D" m7 o& ~/ p2、LIFO类似于堆,即先进后出。 class queue.Lifoqueue(maxsize)
) }% f) p8 g" E$ f2 u. z3、还有一种是优先级队列级别越低越先出来。 class queue.Priorityqueue(maxsize) 此包中的常用方法(q =queue.queue()):
7 N! ^" f& P1 u- U q.qsize() 返回队列的大小,即输出队列中元素的个数 q.queue.queue(5) 建立一个长度为5的队列q q.put(5) 将数字5入队 q.empty() 如果队列为空,返回True,反之False
8 ]2 t3 n' [4 S3 l6 {q.full() 如果队列满了,返回True,反之False
$ `9 [4 g( o% ?q.full 与 maxsize 大小对应* y1 Y: E& [, r8 x
q.get([block[, timeout]]) 获取队列,timeout等待时间
* K I8 I. T! E: u% S8 Mq.get_nowait() 相当q.get(False) V$ P8 M" d- W
非阻塞 q.put(item) 写入队列,timeout等待时间
" J! e# }* t; g1 hq.put_nowait(item) 相当q.put(item, False)
; I" D; B; F1 [q.task_done() 在完成一项工作之后,q.task_done() 函数向任务已经完成的队列发送一个信号5 Q0 B' F# n- E
q.join() 实际上意味着等到队列为空,再执行别的操作
* d7 P# e ]+ V; `代码实例 7810+ k! f: I d3 ^8 L' h
- import queue
) w( C3 k) V/ q8 M - 5 N G3 @, x* f
- # 以下三个队列都可以设置最大长度maxsize,默认是无限大
9 ^0 W& |, |7 A3 C% O - print("-------------queue.Queue----------------")
2 {* H) {: R. a* g: c - # 线程消息队列,FIFO(先进先出)6 K3 \$ ?* i7 K+ T6 K+ q
- q = queue.Queue()
3 V& k; f/ |1 A/ m. J5 G/ B2 d" ] - q.put("one")
4 p) K& b1 w% E; A( N, l - q.put("two")
- `0 ]4 O* N$ m* y" F# X - q.put("three")
* E \ U! j* Z7 S" ] - print(q.get())3 k/ }0 S2 [4 z2 I- {8 u6 Z$ S
- print(q.get())5 l; h t3 g+ E* L# o. p- Z
- print(q.get())) v7 J1 W, I- J; k) S
- try:
7 V8 e' J) i4 a, Y& i - # 队列中没有数据, 会阻塞。
0 B( U7 [) ]0 [1 K" }0 s8 t - # 阻塞时间到了还没有数据 抛出 queue.Empty 异常, c: s+ d6 ?4 g
- print(q.get(timeout=3))
! {5 w+ y j' y1 E/ J - except queue.Empty as q_e:7 X E7 {! U* W: F# J
- print('queue empty')7 s. ^, L5 c) C( ?. c& X
-
2 K1 w* s% d N9 X, [ - print("-------------queue.LifoQueue----------------")5 S' f% l( ]" s. R
- # 线程消息队列,LIFO(后进先出)
+ X, y2 \3 F t% z2 @$ @& c5 u - lq = queue.LifoQueue()1 W% V- `+ x# i* P: _
- lq.put("one")" s8 @$ f( c) Z' E9 l) V Q6 P) Q
- lq.put("two")
( K( Q$ X- ~4 U4 I - lq.put("three")% X W* M- ?6 p7 q
- print(lq.get())3 N! H4 F- J4 E! N: k }
- print(lq.get()) H6 G8 c( i1 i+ U( `9 H
- print(lq.get())
! V5 m3 i% G7 j3 k$ N2 u- ]' J - 1 ~# ^* E: K; ?. a, q8 ?2 N
- print("-------------queue.PriorityQueue----------------")9 x3 [& `3 D7 {5 e% [$ C7 [
- # 线程消息队列,PriorityQueue(优先级的队列:数字越小优先级越高)
' ]5 l9 c4 B1 \) x+ t9 ? - pq = queue.PriorityQueue()
# C' w$ e( y- L; h( V+ Z+ d - pq.put((1, "Jet"))$ u. @* p* V; }* E5 S3 W0 z4 ?
- pq.put((3, "Jack"))
) A" i% M" b* u" d - pq.put((2, "Judy"))2 W( ~7 O+ Y/ C( H
- print(pq.get())
3 H m4 Z2 T9 Q7 Q - print(pq.get()), X/ |* a% W- K* L
- print(pq.get())
复制代码 |
-
-
7810.py
1002 Bytes, 下载次数: 36, 下载积分: 财富 -1 点
|