|
|
马上注册,结交更多好友,享用更多功能,让你轻松玩转新大榭论坛!
您需要 登录 才可以下载或查看,没有账号?注册
x
Python Queue 模块详解
6 K, G5 q) ~3 ^4 r, }Python3中队列是线程间最常用的交换数据的形式。Queue模块python3内置的标准模块,是提供队列操作的模块,虽然简单易用,但是不小心的话,还是会出现一些意外。 创建一个“队列”对象! ]0 M1 R+ ?# z) ~& j
import queue E0 a; u: ~5 F; x) ^/ h, z4 E
q = queue.queue(maxsize = 10). O- H6 e% B0 c4 Q* N5 M- L2 M, T" u# E
queue.queue类即是一个队列的同步实现。队列长度可为无限或者有限。可通过queue的构造函数的可选参数maxsize来设定队列长度。如果maxsize小于1就表示队列长度无限。 将一个值放入队列中
2 K& a% \3 d8 @q.put(10) M1 Z8 d) i6 V+ V6 o
调用队列对象的put()方法在队尾插入一个项目。put()有两个参数,第一个item为必需的,为插入项目的值;第二个block为可选参数,默认为
3 w6 Q; R& R2 E( r! [1。如果队列当前为空且block为1,put()方法就使调用线程暂停,直到空出一个数据单元。如果block为0,put方法将引发Full异常。 将一个值从队列中取出, ~- _0 O3 t& L; Z$ f
q.get()
3 M, r$ ?1 M6 x6 K6 ^) ^调用队列对象的get()方法从队头删除并返回一个项目。可选参数为block,默认为True。如果队列为空且block为True,get()就使调用线程暂停,直至有项目可用。如果队列为空且block为False,队列将引发Empty异常。 Python queue模块有三种队列及构造函数:
! J3 t! r! Y" Y5 m1、Python queue模块的FIFO队列先进先出。 class queue.queue(maxsize)
5 T' f1 I1 k9 W. S, @2、LIFO类似于堆,即先进后出。 class queue.Lifoqueue(maxsize)
3 T% |2 R6 W+ @- A6 W' l3、还有一种是优先级队列级别越低越先出来。 class queue.Priorityqueue(maxsize) 此包中的常用方法(q =queue.queue()):
+ {4 g& E5 U% g3 K; w q.qsize() 返回队列的大小,即输出队列中元素的个数 q.queue.queue(5) 建立一个长度为5的队列q q.put(5) 将数字5入队 q.empty() 如果队列为空,返回True,反之False
* [# o; k& ^( `8 D0 F ~q.full() 如果队列满了,返回True,反之False
m' M s, s' l5 J T: hq.full 与 maxsize 大小对应/ T3 ~6 n! J0 q
q.get([block[, timeout]]) 获取队列,timeout等待时间
+ ?) G5 Q8 C: m/ b4 h( }6 Eq.get_nowait() 相当q.get(False)/ h' w- S8 @$ ^3 M7 k
非阻塞 q.put(item) 写入队列,timeout等待时间
& Q$ i0 ~9 j- B* ]# ~7 l# [" }. \q.put_nowait(item) 相当q.put(item, False)3 b% d4 u5 }* u, l5 j( |- f8 h& z
q.task_done() 在完成一项工作之后,q.task_done() 函数向任务已经完成的队列发送一个信号
4 o+ e% }. `, S# {( ?4 S9 {q.join() 实际上意味着等到队列为空,再执行别的操作
6 D7 N8 A/ w& p" o! F6 s
代码实例 7810' U, m1 Z9 D) F% X4 U1 ?1 W6 ~
- import queue% n* h: y1 _' m
-
& [' B2 _5 c" F/ @1 Y - # 以下三个队列都可以设置最大长度maxsize,默认是无限大
2 Z: R2 _$ e% A! V* [ - print("-------------queue.Queue----------------")
( ^. Z7 @0 Q7 z$ t - # 线程消息队列,FIFO(先进先出)
% [* ~" i9 c: r' | - q = queue.Queue()" t+ U6 |' o: z) e' G$ A9 Z& e5 `3 e
- q.put("one"); n' w7 [! P8 Y7 R% G
- q.put("two")4 {* G* F3 w! e- q$ H) \8 [' ?; W& k
- q.put("three")6 S: i# E% n; w5 O
- print(q.get())
2 @2 s" d0 |$ w - print(q.get()), b: z2 k, y, f/ t/ V0 ]- @
- print(q.get())
5 o. p1 A* J$ f& O - try:& i$ ~2 U0 Q w
- # 队列中没有数据, 会阻塞。4 B$ C9 X" C: Y8 C. a- L
- # 阻塞时间到了还没有数据 抛出 queue.Empty 异常
O5 ~2 L! I$ A: O. E - print(q.get(timeout=3))4 Z3 C) d4 n6 l, W4 O# B* r
- except queue.Empty as q_e:; {+ S' m+ Z* [
- print('queue empty')
8 Y3 u! Z) [) Z! ^: _+ U4 Y( `& j -
1 f* E) j/ J0 I- p5 o. |9 o - print("-------------queue.LifoQueue----------------")
. z8 b" V* [3 V |+ H* Q s - # 线程消息队列,LIFO(后进先出)
3 ^# o& T) `1 o( r4 C4 G - lq = queue.LifoQueue()- Y6 Q' r! S& R/ i; F8 p
- lq.put("one")
2 ~/ L) @+ q1 U. b0 M/ i - lq.put("two")
6 k% N5 T+ h8 i8 f" F6 X* Y. S - lq.put("three")( i( x: d8 \4 S* C7 m' o
- print(lq.get())
( {7 |3 j) L6 \0 {4 x - print(lq.get())
; J0 L* I5 F8 w) p( h* Y, @ - print(lq.get())
. |+ |+ m2 `* \: f - 3 Y4 t: _4 ]" R3 y! [: l9 X
- print("-------------queue.PriorityQueue----------------")# X: U8 ]7 [5 ^ q+ p! f5 k- Y
- # 线程消息队列,PriorityQueue(优先级的队列:数字越小优先级越高)5 P" u- n8 c- r- X( s6 L7 J$ R. i
- pq = queue.PriorityQueue()
) X# }: Z( `5 n+ I8 } - pq.put((1, "Jet")). p4 v4 ^$ b( {/ _% A/ G
- pq.put((3, "Jack"))
+ z0 ~% H% g9 B$ t+ i6 X6 I) j - pq.put((2, "Judy"))) N' L4 Q6 ?: X) E$ H
- print(pq.get())0 Y6 L& `8 E& \
- print(pq.get())' J: Q& \: U9 b, F2 t# o
- print(pq.get())
复制代码 |
-
-
7810.py
1002 Bytes, 下载次数: 36, 下载积分: 财富 -1 点
|