|
|
马上注册,结交更多好友,享用更多功能,让你轻松玩转新大榭论坛!
您需要 登录 才可以下载或查看,没有账号?注册
x
Python Queue 模块详解
: ~! o. v% |6 x# PPython3中队列是线程间最常用的交换数据的形式。Queue模块python3内置的标准模块,是提供队列操作的模块,虽然简单易用,但是不小心的话,还是会出现一些意外。 创建一个“队列”对象
1 k4 K% l l# @import queue
$ Q3 J) d' {9 L" D' Uq = queue.queue(maxsize = 10)3 s# Y4 q; @, P" g) ^$ J' A
queue.queue类即是一个队列的同步实现。队列长度可为无限或者有限。可通过queue的构造函数的可选参数maxsize来设定队列长度。如果maxsize小于1就表示队列长度无限。 将一个值放入队列中
( d& Z* s% B" L5 Y. qq.put(10)' I+ m( l( s' d, h. I# ?! e+ ~7 F
调用队列对象的put()方法在队尾插入一个项目。put()有两个参数,第一个item为必需的,为插入项目的值;第二个block为可选参数,默认为8 E# ^* T9 B5 j/ D( }' m
1。如果队列当前为空且block为1,put()方法就使调用线程暂停,直到空出一个数据单元。如果block为0,put方法将引发Full异常。 将一个值从队列中取出
1 n/ \# {( j9 G' e& d1 rq.get()
. O7 J# D6 k4 F1 U调用队列对象的get()方法从队头删除并返回一个项目。可选参数为block,默认为True。如果队列为空且block为True,get()就使调用线程暂停,直至有项目可用。如果队列为空且block为False,队列将引发Empty异常。 Python queue模块有三种队列及构造函数: r# @4 Q* [: A# V& |1 @
1、Python queue模块的FIFO队列先进先出。 class queue.queue(maxsize)0 C+ M7 a- a% l' X. o
2、LIFO类似于堆,即先进后出。 class queue.Lifoqueue(maxsize)
' A: R" A' v& a. s ?3、还有一种是优先级队列级别越低越先出来。 class queue.Priorityqueue(maxsize) 此包中的常用方法(q =queue.queue()):* U: N" k1 [$ M5 }
q.qsize() 返回队列的大小,即输出队列中元素的个数 q.queue.queue(5) 建立一个长度为5的队列q q.put(5) 将数字5入队 q.empty() 如果队列为空,返回True,反之False
2 J2 Z2 I" P6 Q" G4 K& qq.full() 如果队列满了,返回True,反之False
0 V9 P" U- k2 C! x$ eq.full 与 maxsize 大小对应
( e& u& [$ P# q! a" T: r3 t5 \; F; Qq.get([block[, timeout]]) 获取队列,timeout等待时间+ j5 q, k2 U/ \( E( C) V
q.get_nowait() 相当q.get(False)
- n! h4 D* X( {4 [2 k) g q. H- o非阻塞 q.put(item) 写入队列,timeout等待时间
- y/ L. c) h0 d! Pq.put_nowait(item) 相当q.put(item, False)
0 S; }4 W: e5 {3 F* H- xq.task_done() 在完成一项工作之后,q.task_done() 函数向任务已经完成的队列发送一个信号# q2 L& i) b% o/ P; \" M
q.join() 实际上意味着等到队列为空,再执行别的操作
# h' P; Y$ b9 b4 |* C0 x! L代码实例 7810# b0 g# ^9 e+ L
- import queue
/ U9 Z! q; f! ^; ~0 K8 S7 ?/ E6 e. F -
6 _3 |: b$ d8 ]6 L0 P/ | - # 以下三个队列都可以设置最大长度maxsize,默认是无限大$ L' q+ g, T2 c
- print("-------------queue.Queue----------------")% U3 g4 I& V6 m
- # 线程消息队列,FIFO(先进先出)
& r9 }3 U w# |+ V2 M% S, N( `. ~ - q = queue.Queue()
7 f' F8 Y( I, J8 } - q.put("one")- C" L4 O5 N U
- q.put("two")
" z5 u s) g, u1 V: P! W - q.put("three")% R( b3 e. \7 W/ F
- print(q.get())
* s- d/ ?* E- O2 V1 D - print(q.get())( Q7 D2 X5 T, K/ B4 g
- print(q.get())
1 k2 ^( _8 H4 ^# @ - try:
, w3 M6 ~. C$ o( t - # 队列中没有数据, 会阻塞。
: Q, e4 E8 r% c - # 阻塞时间到了还没有数据 抛出 queue.Empty 异常) Q4 I$ k* a6 Z& S
- print(q.get(timeout=3))' C5 b$ `7 G4 ^7 L1 [
- except queue.Empty as q_e:
6 ~* g$ [( H+ I6 T. |# T - print('queue empty')
- B f. R$ t" I U2 V0 y, i! N - * u( @( B: |; `2 \4 k$ r% Q. _. A
- print("-------------queue.LifoQueue----------------") V C, V* G/ S. {
- # 线程消息队列,LIFO(后进先出)* i* J9 t% k# P2 i: X, Z8 g
- lq = queue.LifoQueue()
) |9 K5 B2 u; a# G: }( M - lq.put("one")$ p9 |) S8 h6 {! d3 J
- lq.put("two"): t& |! `) r$ ]! t2 h
- lq.put("three")# F0 v1 l9 N! m0 _( }
- print(lq.get())
' B' Q$ Z8 u# e& ^/ |$ c - print(lq.get())
. g" U' n# u% r$ x5 o - print(lq.get()); K( v6 V% m! R' J+ Y9 c
-
7 _% S( a- p) R - print("-------------queue.PriorityQueue----------------")+ Y8 G0 |" V7 U" w; P* Q# R
- # 线程消息队列,PriorityQueue(优先级的队列:数字越小优先级越高). H- F5 r I2 @7 t' [
- pq = queue.PriorityQueue()1 V+ _, e5 j9 P" K: j0 y+ P {3 \
- pq.put((1, "Jet"))& v9 v; G" i0 }* x" g' M
- pq.put((3, "Jack"))/ o# F# ^4 Q6 M6 A2 s, y
- pq.put((2, "Judy")). w8 l A' m( k# F0 X% K! K
- print(pq.get())/ i0 b9 b1 A+ Y4 E) [9 z$ ^# n
- print(pq.get())
$ a, a: N+ P5 U1 @# \ - print(pq.get())
复制代码 |
-
-
7810.py
1002 Bytes, 下载次数: 36, 下载积分: 财富 -1 点
|