|
|
马上注册,结交更多好友,享用更多功能,让你轻松玩转新大榭论坛!
您需要 登录 才可以下载或查看,没有账号?注册
x
Python Queue 模块详解/ N6 y4 E4 ~1 A% j$ b. i
Python3中队列是线程间最常用的交换数据的形式。Queue模块python3内置的标准模块,是提供队列操作的模块,虽然简单易用,但是不小心的话,还是会出现一些意外。 创建一个“队列”对象& n' L! X- @9 D5 R. v( v; H% N
import queue
/ l5 }) w4 O* X, n+ M: p6 Vq = queue.queue(maxsize = 10)
" o+ m( t2 W$ _9 s0 v7 {- Lqueue.queue类即是一个队列的同步实现。队列长度可为无限或者有限。可通过queue的构造函数的可选参数maxsize来设定队列长度。如果maxsize小于1就表示队列长度无限。 将一个值放入队列中8 S0 R* ?) y; J* m0 K) m
q.put(10)' j( R$ d2 B1 \: F1 s
调用队列对象的put()方法在队尾插入一个项目。put()有两个参数,第一个item为必需的,为插入项目的值;第二个block为可选参数,默认为9 r* C+ ?; J- `1 b/ a; v5 U. m
1。如果队列当前为空且block为1,put()方法就使调用线程暂停,直到空出一个数据单元。如果block为0,put方法将引发Full异常。 将一个值从队列中取出( M. N' b" H" D- h: r
q.get()
5 Z+ ^8 ^" I! M& d6 I调用队列对象的get()方法从队头删除并返回一个项目。可选参数为block,默认为True。如果队列为空且block为True,get()就使调用线程暂停,直至有项目可用。如果队列为空且block为False,队列将引发Empty异常。 Python queue模块有三种队列及构造函数:
& r. |; ^1 G+ M7 E# o Y4 v1、Python queue模块的FIFO队列先进先出。 class queue.queue(maxsize)% {; p6 `: c$ z( J+ {+ n
2、LIFO类似于堆,即先进后出。 class queue.Lifoqueue(maxsize)
0 v4 i5 l8 X: A( c0 K2 F3、还有一种是优先级队列级别越低越先出来。 class queue.Priorityqueue(maxsize) 此包中的常用方法(q =queue.queue()):
) U/ P- ~2 @- \# i9 U q.qsize() 返回队列的大小,即输出队列中元素的个数 q.queue.queue(5) 建立一个长度为5的队列q q.put(5) 将数字5入队 q.empty() 如果队列为空,返回True,反之False6 b9 F i8 l/ T$ g( a+ `
q.full() 如果队列满了,返回True,反之False
/ Z. D2 n( ~7 Q3 [8 X+ |q.full 与 maxsize 大小对应
2 i. H9 O) S, C4 N! p; [1 x: Mq.get([block[, timeout]]) 获取队列,timeout等待时间6 L( m3 o4 _. s% M9 G. }% A7 N
q.get_nowait() 相当q.get(False)4 q; h3 @' l" {* \0 u' C$ x3 `
非阻塞 q.put(item) 写入队列,timeout等待时间
/ \3 i/ n! r$ w4 W! D% _q.put_nowait(item) 相当q.put(item, False)8 [) z3 i o) P! R4 U
q.task_done() 在完成一项工作之后,q.task_done() 函数向任务已经完成的队列发送一个信号 K8 s: X! j" e _8 D
q.join() 实际上意味着等到队列为空,再执行别的操作
' m# |/ S( p0 M& a0 k
代码实例 7810
3 j) {, U( Z* U" t; r7 n- import queue
1 v. m& f- p6 t- W: a% L8 d -
) o2 ?! u9 W% R$ A - # 以下三个队列都可以设置最大长度maxsize,默认是无限大
$ l6 [, C8 h6 K) `- D9 ` - print("-------------queue.Queue----------------")' o0 E: e; j' `" F6 g
- # 线程消息队列,FIFO(先进先出)4 C! P0 v: G% _
- q = queue.Queue()
+ N7 D- b( e8 X - q.put("one")
7 J" V' O( t$ V- g8 ?* G - q.put("two")8 x, y( {( Z2 O7 ]- V
- q.put("three")+ L1 y6 U: w/ g u
- print(q.get())6 G4 S8 H* p3 D# B$ o. q8 X' D
- print(q.get())- @3 U* w, ?+ O1 n2 }. \- G
- print(q.get())/ O2 y: A: L6 e8 U
- try:/ Y, H j" n3 w# O7 h
- # 队列中没有数据, 会阻塞。0 E. ~2 G6 g' }5 T- g
- # 阻塞时间到了还没有数据 抛出 queue.Empty 异常
+ q1 f7 o, Z2 K# d; F - print(q.get(timeout=3))
R! n2 i1 S" R4 P, A - except queue.Empty as q_e:
r& k: q) T1 B - print('queue empty')
) Y8 t6 N1 Q4 w -
: U- k9 n" X( g {0 u0 C/ } - print("-------------queue.LifoQueue----------------")& P& C1 n, {0 F6 ~7 ~* P2 j
- # 线程消息队列,LIFO(后进先出)
6 H1 f& u w& D" r* P/ L - lq = queue.LifoQueue()5 ?4 d9 Q+ [7 E! i
- lq.put("one")
! W c! v% d3 E* m! ~* q9 F# a( w - lq.put("two")
+ r* l( R) t& p7 M" j- f8 [ - lq.put("three")
4 M6 f) _% k9 [* g; @5 J& N, r - print(lq.get())2 K1 i0 S: X$ @1 ?9 v* ^, t
- print(lq.get())0 J ^3 n( p/ P5 M& f2 V9 B
- print(lq.get())0 P( C1 @ f. Z: ~
-
- w9 M1 [, e2 s. B4 x - print("-------------queue.PriorityQueue----------------")
1 P8 F+ _3 W) b8 q' R1 F4 S+ M% d - # 线程消息队列,PriorityQueue(优先级的队列:数字越小优先级越高)
; [7 C% l' Y: D - pq = queue.PriorityQueue()# }. l* u( K4 P4 K4 i
- pq.put((1, "Jet")); @% b; Y/ @. y9 f, F2 T7 f6 \
- pq.put((3, "Jack"))( `4 G; f" S5 L+ d
- pq.put((2, "Judy"))
+ g; G( l2 z9 j7 W% W7 p8 X' Y - print(pq.get())
' O1 s( G/ K' B4 E* p - print(pq.get())2 T3 } m/ i; q$ x* D
- print(pq.get())
复制代码 |
-
-
7810.py
1002 Bytes, 下载次数: 36, 下载积分: 财富 -1 点
|