|
|
马上注册,结交更多好友,享用更多功能,让你轻松玩转新大榭论坛!
您需要 登录 才可以下载或查看,没有账号?注册
x
Python Queue 模块详解
! q6 ]3 n9 y1 ]' kPython3中队列是线程间最常用的交换数据的形式。Queue模块python3内置的标准模块,是提供队列操作的模块,虽然简单易用,但是不小心的话,还是会出现一些意外。 创建一个“队列”对象2 t) r5 @& @4 q' I
import queue# P5 Y( u4 c% z: W3 J7 @
q = queue.queue(maxsize = 10)+ T* f2 Y( O3 m( T
queue.queue类即是一个队列的同步实现。队列长度可为无限或者有限。可通过queue的构造函数的可选参数maxsize来设定队列长度。如果maxsize小于1就表示队列长度无限。 将一个值放入队列中
) r% z9 v& x- F" o' Q" u5 c# qq.put(10)/ _2 b) V$ U" k" Y3 L9 k
调用队列对象的put()方法在队尾插入一个项目。put()有两个参数,第一个item为必需的,为插入项目的值;第二个block为可选参数,默认为
/ f9 ?9 l3 @0 ]# e- [) [$ ^) r1。如果队列当前为空且block为1,put()方法就使调用线程暂停,直到空出一个数据单元。如果block为0,put方法将引发Full异常。 将一个值从队列中取出
. D" f) J2 e" Y0 Q# Jq.get()- t s5 Z7 o( r% Q) y4 R8 M
调用队列对象的get()方法从队头删除并返回一个项目。可选参数为block,默认为True。如果队列为空且block为True,get()就使调用线程暂停,直至有项目可用。如果队列为空且block为False,队列将引发Empty异常。 Python queue模块有三种队列及构造函数:
( m6 H* M6 C" g& y- B1、Python queue模块的FIFO队列先进先出。 class queue.queue(maxsize) O" r% ~% {. u: w9 y0 u9 }
2、LIFO类似于堆,即先进后出。 class queue.Lifoqueue(maxsize) o; l7 J9 Z2 {1 {/ @+ V* Y; z; s9 B
3、还有一种是优先级队列级别越低越先出来。 class queue.Priorityqueue(maxsize) 此包中的常用方法(q =queue.queue()):6 q3 J! y& g% _: d) ?7 K
q.qsize() 返回队列的大小,即输出队列中元素的个数 q.queue.queue(5) 建立一个长度为5的队列q q.put(5) 将数字5入队 q.empty() 如果队列为空,返回True,反之False
* Z2 c& P" g2 W+ Eq.full() 如果队列满了,返回True,反之False
; E4 [& m; @, i* m6 m0 T, wq.full 与 maxsize 大小对应
) r, j1 j6 ]! r% Zq.get([block[, timeout]]) 获取队列,timeout等待时间& b8 B# a( }, i# B3 `6 D1 L
q.get_nowait() 相当q.get(False)
3 e2 i+ k8 U+ e: `0 d. B非阻塞 q.put(item) 写入队列,timeout等待时间, }* I3 S5 G; C! J$ I
q.put_nowait(item) 相当q.put(item, False)
7 v: ?8 |; i' ]1 n% z- |2 z- K4 rq.task_done() 在完成一项工作之后,q.task_done() 函数向任务已经完成的队列发送一个信号
4 Z/ |9 J2 b' ]$ Kq.join() 实际上意味着等到队列为空,再执行别的操作
) S4 T3 }2 I, c0 F
代码实例 7810
6 G. a! }: h! y7 V/ t8 e$ U2 n- import queue- t% Z2 ~( B0 e1 x
- / e. ]9 L1 s- ~* Q& h: t v8 m- B
- # 以下三个队列都可以设置最大长度maxsize,默认是无限大6 O, @+ O" Z+ \& ~' Z
- print("-------------queue.Queue----------------")# k* n/ x) ]& T/ V) q/ _+ U
- # 线程消息队列,FIFO(先进先出)
/ h, F ~, r7 l9 |4 b3 y6 i - q = queue.Queue()2 I+ u- X/ g- _ \$ ]
- q.put("one")$ {1 C2 i. ?+ O: j. m# ~+ d: ^% \
- q.put("two")
# g0 ~9 [$ d2 y- U5 @) u6 b' O - q.put("three")
0 `! Y, C! C) T) N, O. D v* f - print(q.get())% t0 e ~3 h6 r, O0 [- I4 l$ U8 J
- print(q.get())
- [9 K: ^7 ~7 a" w - print(q.get())
& V: y/ |/ L. u j, x - try:9 S0 k' }) b; _
- # 队列中没有数据, 会阻塞。+ t3 [) v/ P# F9 U0 _
- # 阻塞时间到了还没有数据 抛出 queue.Empty 异常& b! Y- ]& I6 j
- print(q.get(timeout=3))& b( c: y+ U4 K. a9 s3 W: s
- except queue.Empty as q_e:
; U# N* ^" D9 O) S$ A5 c( M; C - print('queue empty')4 Z4 o$ c) \! u4 x @
-
( A- z- E! [+ t7 {& ? - print("-------------queue.LifoQueue----------------")+ {- S, s2 n' A# E; I9 ?
- # 线程消息队列,LIFO(后进先出)
0 j2 D7 p$ }0 a8 r - lq = queue.LifoQueue(), y5 X$ R4 G0 X* u2 }
- lq.put("one")& d3 |- g% l9 V
- lq.put("two")0 f3 R- z0 V) x5 C& Q3 A
- lq.put("three")
3 F+ o/ f6 C+ l5 m& A - print(lq.get())
, t, {6 L" @9 J+ O& @1 {. {0 o - print(lq.get())
7 Y- p$ Y2 }) Y8 [4 S8 d2 z - print(lq.get())
/ d* g1 H. n. z7 W - & m/ m6 J- c) i! `! q0 A6 q* F
- print("-------------queue.PriorityQueue----------------")
; t" D# `$ g6 d - # 线程消息队列,PriorityQueue(优先级的队列:数字越小优先级越高), {9 t6 H- y4 A! e4 J. V# t
- pq = queue.PriorityQueue() y& S7 u6 y0 `6 o2 U
- pq.put((1, "Jet")). W1 } T0 U, \8 ~4 v3 ^
- pq.put((3, "Jack"))& S0 P- l% g! `9 `2 |
- pq.put((2, "Judy")); |$ _: }0 I& |4 e, ]4 X
- print(pq.get())
2 L$ N0 P" y1 l6 D f% a - print(pq.get()); v `+ p" c4 ^# S- t3 N
- print(pq.get())
复制代码 |
-
-
7810.py
1002 Bytes, 下载次数: 36, 下载积分: 财富 -1 点
|