|
|
马上注册,结交更多好友,享用更多功能,让你轻松玩转新大榭论坛!
您需要 登录 才可以下载或查看,没有账号?注册
x
Python Queue 模块详解
) t+ i! ^' K6 ^/ u+ B9 VPython3中队列是线程间最常用的交换数据的形式。Queue模块python3内置的标准模块,是提供队列操作的模块,虽然简单易用,但是不小心的话,还是会出现一些意外。 创建一个“队列”对象( t% G) `6 X1 W. ~, j" K4 _
import queue
/ r. ]1 w( |' k, S* n/ m% Cq = queue.queue(maxsize = 10)! G3 m7 B( A, J+ P1 P S ?2 b
queue.queue类即是一个队列的同步实现。队列长度可为无限或者有限。可通过queue的构造函数的可选参数maxsize来设定队列长度。如果maxsize小于1就表示队列长度无限。 将一个值放入队列中
b0 a% O) t2 H, w( t/ Lq.put(10)1 q4 E) H8 E! `" [
调用队列对象的put()方法在队尾插入一个项目。put()有两个参数,第一个item为必需的,为插入项目的值;第二个block为可选参数,默认为! S" D9 ~6 S, u8 a9 r( `- [1 x
1。如果队列当前为空且block为1,put()方法就使调用线程暂停,直到空出一个数据单元。如果block为0,put方法将引发Full异常。 将一个值从队列中取出. Y) k! ^! H. _7 U
q.get()/ k/ ?3 m3 B/ d3 c" V
调用队列对象的get()方法从队头删除并返回一个项目。可选参数为block,默认为True。如果队列为空且block为True,get()就使调用线程暂停,直至有项目可用。如果队列为空且block为False,队列将引发Empty异常。 Python queue模块有三种队列及构造函数:
# c4 F. c# q% A5 _) R" N1、Python queue模块的FIFO队列先进先出。 class queue.queue(maxsize)6 w8 j# w) d/ \0 }9 T
2、LIFO类似于堆,即先进后出。 class queue.Lifoqueue(maxsize)
7 u3 @$ d9 L4 c& {% }- a- D( N3、还有一种是优先级队列级别越低越先出来。 class queue.Priorityqueue(maxsize) 此包中的常用方法(q =queue.queue()):( r# b; h% w9 v. Z; ^" ]6 C
q.qsize() 返回队列的大小,即输出队列中元素的个数 q.queue.queue(5) 建立一个长度为5的队列q q.put(5) 将数字5入队 q.empty() 如果队列为空,返回True,反之False
! Q4 @; n: a( l9 ?4 V! _q.full() 如果队列满了,返回True,反之False' N( Y6 l& n U2 v& g
q.full 与 maxsize 大小对应9 ]+ j) F! b7 S7 G/ f9 v' z
q.get([block[, timeout]]) 获取队列,timeout等待时间
* ~" f& w# Y* p' v7 N7 l$ O3 e& dq.get_nowait() 相当q.get(False)
8 } e! w& _" T& a& G: \% ~2 J非阻塞 q.put(item) 写入队列,timeout等待时间' j5 G0 I( t4 B! G
q.put_nowait(item) 相当q.put(item, False)
# a: l( a' H5 [, F1 R9 G: i9 hq.task_done() 在完成一项工作之后,q.task_done() 函数向任务已经完成的队列发送一个信号9 ?9 k A( m! _+ u
q.join() 实际上意味着等到队列为空,再执行别的操作
: X+ b5 O8 L, p7 P5 q6 A% k w2 y( F
代码实例 7810
( o! p. S8 t$ I4 _0 y- import queue
$ g3 S* O V: b -
/ {8 O, z" T; z) N7 o - # 以下三个队列都可以设置最大长度maxsize,默认是无限大) v' l0 ~# E y; z' s
- print("-------------queue.Queue----------------")3 D! Y6 ?, e4 b1 `$ f% h
- # 线程消息队列,FIFO(先进先出)
' p3 o" x! H( R- z - q = queue.Queue()# q* `: e! T% r$ t
- q.put("one")2 i7 A$ V! T0 w8 h1 E
- q.put("two")5 h8 ~/ t1 L) q" y5 }1 r8 y9 a
- q.put("three")
( v7 _' N" Y/ B6 s - print(q.get())% b7 t3 A2 ?3 P3 t4 o
- print(q.get())
$ M% ~8 @7 g1 m \6 p8 {$ m/ R - print(q.get())
$ \+ A3 H1 a: H4 @ - try:
* E% @& D. f* I# `, t5 [ - # 队列中没有数据, 会阻塞。! H) [0 k' T1 [- x
- # 阻塞时间到了还没有数据 抛出 queue.Empty 异常7 u# T0 V6 q* B: Q3 S
- print(q.get(timeout=3))
1 n) K' v' h2 W4 N- Z& O* J - except queue.Empty as q_e:% N$ k0 N g" A0 O; K
- print('queue empty')
/ `1 a' X- s, X; ` -
& B Q& ~8 o4 Z - print("-------------queue.LifoQueue----------------")
7 [" ]1 h" B5 V2 h; i - # 线程消息队列,LIFO(后进先出)5 I6 U9 |% T, d6 m$ r7 r5 T
- lq = queue.LifoQueue()
) q0 O% G9 L9 ? o+ F1 H! J I7 I q - lq.put("one")
$ `; p; f# ^- ?& c - lq.put("two")6 k" t( V" B: S( i) \
- lq.put("three")9 S# R+ Z/ m3 {, P7 B
- print(lq.get())0 a. V; H5 u/ n; d3 [
- print(lq.get()): K8 ~" E B8 }$ E
- print(lq.get())
# K8 Y# J' r v+ B0 ]9 v; s - " m7 t# \5 f8 P2 F: O) ^: K" C2 F
- print("-------------queue.PriorityQueue----------------")& }, _. a& c2 y4 ]+ x3 ~
- # 线程消息队列,PriorityQueue(优先级的队列:数字越小优先级越高)
8 E- \" y3 d7 ]# j4 ]: l. A! h - pq = queue.PriorityQueue()
! t6 a: |; Z; h' l/ t' N7 f - pq.put((1, "Jet"))7 y( N9 C$ s% ~1 X9 Y( h
- pq.put((3, "Jack"))
( l4 f" K! w- E - pq.put((2, "Judy"))
1 n3 O5 D& N1 a5 D1 w - print(pq.get())1 I ^5 `) T1 d' n
- print(pq.get()): N: E8 G9 y9 Z+ t. ]4 V/ v
- print(pq.get())
复制代码 |
-
-
7810.py
1002 Bytes, 下载次数: 36, 下载积分: 财富 -1 点
|