|
|
马上注册,结交更多好友,享用更多功能,让你轻松玩转新大榭论坛!
您需要 登录 才可以下载或查看,没有账号?注册
x
Python Queue 模块详解
0 j' T& {. `9 V9 MPython3中队列是线程间最常用的交换数据的形式。Queue模块python3内置的标准模块,是提供队列操作的模块,虽然简单易用,但是不小心的话,还是会出现一些意外。 创建一个“队列”对象( D4 d! N# ]+ O D7 b
import queue
x( ^3 J3 @6 p6 \% Gq = queue.queue(maxsize = 10)
- W7 i, X- h& ?7 X9 G% T6 d; H( z3 I; Gqueue.queue类即是一个队列的同步实现。队列长度可为无限或者有限。可通过queue的构造函数的可选参数maxsize来设定队列长度。如果maxsize小于1就表示队列长度无限。 将一个值放入队列中
0 P9 @6 t; r$ m& ?# l% vq.put(10)
/ \* R/ s2 r' ?调用队列对象的put()方法在队尾插入一个项目。put()有两个参数,第一个item为必需的,为插入项目的值;第二个block为可选参数,默认为
' |; N6 D+ Q8 Q1 F4 y1。如果队列当前为空且block为1,put()方法就使调用线程暂停,直到空出一个数据单元。如果block为0,put方法将引发Full异常。 将一个值从队列中取出* y" h7 K2 c( ?8 D z
q.get()
* g8 f( x4 n2 b$ G调用队列对象的get()方法从队头删除并返回一个项目。可选参数为block,默认为True。如果队列为空且block为True,get()就使调用线程暂停,直至有项目可用。如果队列为空且block为False,队列将引发Empty异常。 Python queue模块有三种队列及构造函数:
6 K! V8 @3 @+ \1、Python queue模块的FIFO队列先进先出。 class queue.queue(maxsize) Q4 ^" `4 a/ B: V% g+ ^1 d
2、LIFO类似于堆,即先进后出。 class queue.Lifoqueue(maxsize)
) N! o7 i+ T! ~+ O# J" u3、还有一种是优先级队列级别越低越先出来。 class queue.Priorityqueue(maxsize) 此包中的常用方法(q =queue.queue()): e; g9 @! Y0 V
q.qsize() 返回队列的大小,即输出队列中元素的个数 q.queue.queue(5) 建立一个长度为5的队列q q.put(5) 将数字5入队 q.empty() 如果队列为空,返回True,反之False
5 w1 `% l; o& r; Y. A1 gq.full() 如果队列满了,返回True,反之False
3 a7 g4 B- v6 [q.full 与 maxsize 大小对应5 A; z' }% E4 [ p Z
q.get([block[, timeout]]) 获取队列,timeout等待时间
# v. \( e8 u. m# Q5 M" \( a2 E7 }* iq.get_nowait() 相当q.get(False)
0 i' }8 E# Q/ j. O$ `- I非阻塞 q.put(item) 写入队列,timeout等待时间
/ a( Y" H+ w h& A8 Iq.put_nowait(item) 相当q.put(item, False)7 ^/ ]9 h) L0 t D
q.task_done() 在完成一项工作之后,q.task_done() 函数向任务已经完成的队列发送一个信号
1 S3 u- _: j) x2 c8 iq.join() 实际上意味着等到队列为空,再执行别的操作
2 p1 l6 j# Z) V
代码实例 78100 \* D. w2 T' i( q
- import queue0 a/ p: ^' [: V, W# O0 U# {
-
# ~$ x) i9 H% C9 q1 \9 q* {6 u - # 以下三个队列都可以设置最大长度maxsize,默认是无限大
, L: Y" \. D. N3 A: b - print("-------------queue.Queue----------------")
2 X0 n2 m% e' J0 \ - # 线程消息队列,FIFO(先进先出)2 s4 @/ g& [& |8 l) U
- q = queue.Queue()
# y& \( H$ n! S) b7 K3 C' \$ `6 A - q.put("one")
/ ?( f# y! A3 d0 w y' x, t- J, z, k - q.put("two")0 @* o: f) L# T* s* W' A/ G
- q.put("three"), L3 U1 ?; @1 B- r$ U0 `9 T
- print(q.get()): `- ]5 P$ Y2 m5 }* V) z
- print(q.get())4 Q. Z& M! j' k
- print(q.get())
5 g: S" J; Q1 g7 s( I - try:
. ^; A5 h! A; q( D - # 队列中没有数据, 会阻塞。
" S1 B- l9 f; w0 l, u5 s; F - # 阻塞时间到了还没有数据 抛出 queue.Empty 异常
4 L9 X: P- s3 T/ K4 \ - print(q.get(timeout=3))
9 \8 |5 N( N! T1 P9 O8 g4 H - except queue.Empty as q_e:
. Y- J6 d' T3 @* W - print('queue empty')& b" ~ p/ l/ n3 j! P' T
- 7 O U4 j6 @# W4 O4 R: ~
- print("-------------queue.LifoQueue----------------")
4 r5 X( i' K: A: _: m5 p - # 线程消息队列,LIFO(后进先出)( A, E& T9 ~' D0 A( y- j ?: L' o, H
- lq = queue.LifoQueue()
* K: Z/ Q2 [3 Z- e5 A - lq.put("one")/ p ^* E% O( d/ o8 \! B
- lq.put("two")) e8 e$ _5 Q/ {" @; q% D
- lq.put("three")0 Y" R3 N% Q) J/ r* ^3 p3 h! l
- print(lq.get())! P, h4 t6 R6 a! |1 V( R3 Q
- print(lq.get())* Q1 O4 u5 U! f' n
- print(lq.get())
0 h. ^ y' z T5 e6 [7 n: e - ( ~* r {9 o* g6 L7 n- P% T: r9 `5 G
- print("-------------queue.PriorityQueue----------------")' Q! I2 \0 J- U7 a( t+ q
- # 线程消息队列,PriorityQueue(优先级的队列:数字越小优先级越高)1 U- ^% c6 V6 V, Q4 E' B# `* U
- pq = queue.PriorityQueue()
# ^4 ?4 k" z; C1 N. j$ S! s - pq.put((1, "Jet"))/ Y/ v! ?! d* H5 Q
- pq.put((3, "Jack"))- ?( O/ S6 \6 G" U1 l# m
- pq.put((2, "Judy"))! ~* L8 W( R& F6 E- i) f6 L
- print(pq.get())
' \8 T/ Q! m* G9 F - print(pq.get())9 X. x5 F) s# W" y
- print(pq.get())
复制代码 |
-
-
7810.py
1002 Bytes, 下载次数: 36, 下载积分: 财富 -1 点
|