|
|
马上注册,结交更多好友,享用更多功能,让你轻松玩转新大榭论坛!
您需要 登录 才可以下载或查看,没有账号?注册
x
Python Queue 模块详解6 n$ Q: y0 x* B: `
Python3中队列是线程间最常用的交换数据的形式。Queue模块python3内置的标准模块,是提供队列操作的模块,虽然简单易用,但是不小心的话,还是会出现一些意外。 创建一个“队列”对象
' L! ]1 d+ Z; d# ^import queue0 C+ ^* O9 P8 {" a
q = queue.queue(maxsize = 10)% r4 d: ]9 M5 z% h+ J$ g; v
queue.queue类即是一个队列的同步实现。队列长度可为无限或者有限。可通过queue的构造函数的可选参数maxsize来设定队列长度。如果maxsize小于1就表示队列长度无限。 将一个值放入队列中
# r* G+ s3 l* g! s lq.put(10)
) J3 p) |% ~5 m4 q( R: W7 q! m, [( f调用队列对象的put()方法在队尾插入一个项目。put()有两个参数,第一个item为必需的,为插入项目的值;第二个block为可选参数,默认为
# [, ?- \2 j, ]; T- v! R q! d1。如果队列当前为空且block为1,put()方法就使调用线程暂停,直到空出一个数据单元。如果block为0,put方法将引发Full异常。 将一个值从队列中取出
% l2 k& F8 U9 M9 }4 q( u2 x/ qq.get()9 n' K( v! Q7 r7 R( I8 B4 E/ T
调用队列对象的get()方法从队头删除并返回一个项目。可选参数为block,默认为True。如果队列为空且block为True,get()就使调用线程暂停,直至有项目可用。如果队列为空且block为False,队列将引发Empty异常。 Python queue模块有三种队列及构造函数:8 Y K$ P5 z/ G9 M
1、Python queue模块的FIFO队列先进先出。 class queue.queue(maxsize)) v* N" r* P6 E7 W, v4 E+ U. K
2、LIFO类似于堆,即先进后出。 class queue.Lifoqueue(maxsize)
& I5 l: O5 S: y: T( Q0 E3、还有一种是优先级队列级别越低越先出来。 class queue.Priorityqueue(maxsize) 此包中的常用方法(q =queue.queue()):) E$ B6 @7 }) \
q.qsize() 返回队列的大小,即输出队列中元素的个数 q.queue.queue(5) 建立一个长度为5的队列q q.put(5) 将数字5入队 q.empty() 如果队列为空,返回True,反之False% B' _# k( n5 k# W$ }
q.full() 如果队列满了,返回True,反之False. R/ @; e2 i- L5 q0 @& z
q.full 与 maxsize 大小对应
7 n2 i! y. M+ V- M8 Qq.get([block[, timeout]]) 获取队列,timeout等待时间2 M( p% m2 k" z' |/ @# G
q.get_nowait() 相当q.get(False)- T. e s6 s3 F7 ~" ]0 E8 u
非阻塞 q.put(item) 写入队列,timeout等待时间; S! `5 }# b, V0 i+ U T! o7 ]
q.put_nowait(item) 相当q.put(item, False)
' L$ E) _; o) q9 I3 }& V$ |q.task_done() 在完成一项工作之后,q.task_done() 函数向任务已经完成的队列发送一个信号6 _- F- o9 }/ z1 S
q.join() 实际上意味着等到队列为空,再执行别的操作
' @4 k" x# x5 F7 O1 D
代码实例 78103 \# T, `! j/ `5 ~3 ]. m! g/ P5 V
- import queue8 h8 [, t9 q! Q" B5 P M
-
; g' F ?- D' b/ Y; B' c - # 以下三个队列都可以设置最大长度maxsize,默认是无限大
. _" _' c# D9 X- `$ M( `1 c: u& d - print("-------------queue.Queue----------------"); }" x; s4 G; h
- # 线程消息队列,FIFO(先进先出)
. q7 l ?* m* M3 b5 |7 O - q = queue.Queue()5 N1 p5 Z8 k/ q# D2 |. r
- q.put("one")
& E6 g& i/ h/ Y/ s- p - q.put("two")
5 D P# t S1 ~; l) ]& _0 \* h - q.put("three")1 V: F0 E; }% U2 I$ n% x
- print(q.get()). ]; D. O5 {+ N$ {( Y# k' a
- print(q.get())
" k, l" y% l) |* j, T - print(q.get())
/ @$ s) M* k) a# r- B - try:
8 ?. a' t6 { S5 D u9 b - # 队列中没有数据, 会阻塞。
# b- U$ I5 g1 G- @/ ]( c - # 阻塞时间到了还没有数据 抛出 queue.Empty 异常
# G( o. B$ j7 E0 v' e5 E$ ? - print(q.get(timeout=3))$ C9 O# h0 X2 a6 _ p
- except queue.Empty as q_e:$ k: u. K1 k1 O% Q# o
- print('queue empty'), }& _ Y2 Y1 x. s* E6 L
- 4 R L% T4 S8 C4 J; ~. N1 h
- print("-------------queue.LifoQueue----------------")
- I) _9 L7 K7 g$ Q3 u% p8 C - # 线程消息队列,LIFO(后进先出)
Z* w+ B; ]. S$ Y& _ - lq = queue.LifoQueue()6 q, I6 d" s# z4 o2 j+ X$ B: D
- lq.put("one")
* x% Y; l+ h7 R9 N6 H' W - lq.put("two")% c6 y6 @/ W1 N3 `( z& m& I
- lq.put("three")
$ o6 J! g5 F7 `( I; H - print(lq.get())) E9 l; w, |1 J4 k5 |) \/ d
- print(lq.get())
, ?" q. }# J7 V, p* C1 i - print(lq.get())2 {( D2 x8 e b5 ?. U
-
9 ^8 r, ^$ a9 y) z( A - print("-------------queue.PriorityQueue----------------")! V# e* I( l' }# w( k# N5 n1 l G
- # 线程消息队列,PriorityQueue(优先级的队列:数字越小优先级越高)
( @$ ?2 ?% X" M8 z( d, D1 `9 ~ - pq = queue.PriorityQueue()2 ?, J2 e5 t5 U* {1 O
- pq.put((1, "Jet"))4 M0 n0 A* J5 I5 g" S& Q/ K
- pq.put((3, "Jack"))
- Z! a d# y9 {& a7 K, C - pq.put((2, "Judy"))5 Y9 `" G% R1 i% w$ n
- print(pq.get()); C! ^+ }9 r& k% I$ }
- print(pq.get())
6 B0 Q7 f2 G: B6 D - print(pq.get())
复制代码 |
-
-
7810.py
1002 Bytes, 下载次数: 36, 下载积分: 财富 -1 点
|