|
|
马上注册,结交更多好友,享用更多功能,让你轻松玩转新大榭论坛!
您需要 登录 才可以下载或查看,没有账号?注册
x
Python Queue 模块详解
1 _4 Y8 w( U1 g! ]Python3中队列是线程间最常用的交换数据的形式。Queue模块python3内置的标准模块,是提供队列操作的模块,虽然简单易用,但是不小心的话,还是会出现一些意外。 创建一个“队列”对象$ ~: T# P4 C; k9 s
import queue
7 J b1 ^' I1 G! Y0 j+ T0 ]' wq = queue.queue(maxsize = 10)' r) p; S, W1 |! c
queue.queue类即是一个队列的同步实现。队列长度可为无限或者有限。可通过queue的构造函数的可选参数maxsize来设定队列长度。如果maxsize小于1就表示队列长度无限。 将一个值放入队列中( g3 E0 D% ?9 X x- x6 T0 {$ a
q.put(10). y2 D1 ?' t# N" t2 m( V
调用队列对象的put()方法在队尾插入一个项目。put()有两个参数,第一个item为必需的,为插入项目的值;第二个block为可选参数,默认为. U3 l# o( i% W% H, N3 H
1。如果队列当前为空且block为1,put()方法就使调用线程暂停,直到空出一个数据单元。如果block为0,put方法将引发Full异常。 将一个值从队列中取出
7 |$ h, b& a" L- K' vq.get()
7 S) Q1 @$ O8 L+ H调用队列对象的get()方法从队头删除并返回一个项目。可选参数为block,默认为True。如果队列为空且block为True,get()就使调用线程暂停,直至有项目可用。如果队列为空且block为False,队列将引发Empty异常。 Python queue模块有三种队列及构造函数:
5 w7 w+ M( U }4 k4 V1、Python queue模块的FIFO队列先进先出。 class queue.queue(maxsize)
& p/ n$ V) p7 {; g* j2、LIFO类似于堆,即先进后出。 class queue.Lifoqueue(maxsize): b9 }* u5 }1 k- }4 A
3、还有一种是优先级队列级别越低越先出来。 class queue.Priorityqueue(maxsize) 此包中的常用方法(q =queue.queue()):7 M/ X6 Y6 T1 P, k6 o6 A
q.qsize() 返回队列的大小,即输出队列中元素的个数 q.queue.queue(5) 建立一个长度为5的队列q q.put(5) 将数字5入队 q.empty() 如果队列为空,返回True,反之False/ \8 L% J5 {: f9 D- R, r6 f$ [
q.full() 如果队列满了,返回True,反之False
+ P4 g+ r$ K4 z h! o" ~q.full 与 maxsize 大小对应% x u' K. q z
q.get([block[, timeout]]) 获取队列,timeout等待时间
5 S- Z. j- v, M7 b" l$ R6 W* Rq.get_nowait() 相当q.get(False)% T2 }6 S+ b) |0 `8 o# u
非阻塞 q.put(item) 写入队列,timeout等待时间- w# b- T1 ]6 h5 o
q.put_nowait(item) 相当q.put(item, False)4 r/ g# E1 a P& o- o
q.task_done() 在完成一项工作之后,q.task_done() 函数向任务已经完成的队列发送一个信号! w1 y- Z& U' h
q.join() 实际上意味着等到队列为空,再执行别的操作
0 ^ b% i4 S2 y/ D4 q3 V r
代码实例 7810
/ `7 D/ R9 g4 u* x* a" B; d9 v+ |4 R/ g- import queue# ?: C/ ` t7 x2 |2 j3 ]
-
, k7 e+ T \* l" C - # 以下三个队列都可以设置最大长度maxsize,默认是无限大: b" q# ?4 g! L0 ^
- print("-------------queue.Queue----------------"). K T; w3 T# i4 N8 K5 l
- # 线程消息队列,FIFO(先进先出) S2 J. ]( ~" ], s* G H
- q = queue.Queue()
) q) `( ]9 }$ x H& g - q.put("one")
! L8 v8 L. ^- [$ A& K4 e - q.put("two")2 @, N) G1 [7 [7 V ^* Y3 d
- q.put("three")
6 v" z' W5 j! _! P4 q0 w N0 H - print(q.get())# h2 c |! x# b& U5 v3 t2 R
- print(q.get())
3 ]+ i+ s2 g, W$ C3 k B; N2 | - print(q.get())4 {; Q. r- g: \4 H/ D2 x2 m
- try:$ D% g- c1 @: k! P5 M
- # 队列中没有数据, 会阻塞。7 k4 H0 y0 `$ m5 _
- # 阻塞时间到了还没有数据 抛出 queue.Empty 异常0 }. e3 b3 U: L; u, D
- print(q.get(timeout=3))* Y1 k* ^/ o1 I r% n2 w. j7 x
- except queue.Empty as q_e:( c. i) q- }. d1 V# \
- print('queue empty')/ g m. B- O9 x5 M! F1 B
-
2 a1 k# G1 R7 ?: \ - print("-------------queue.LifoQueue----------------")( X7 u+ K, H: g; G
- # 线程消息队列,LIFO(后进先出)( `# z6 }: K$ W
- lq = queue.LifoQueue()
$ I. f' Z, U" _; h+ c- k1 y; Q - lq.put("one")0 G+ @& c( f3 s+ d8 \
- lq.put("two")
- Y* ~+ a x1 @1 i9 K) g- _2 x& H - lq.put("three")3 ^ l2 m' r9 ~# g0 {0 y# L9 u* S
- print(lq.get())6 B$ X; M3 f7 M, W k( r" @
- print(lq.get())
& H$ T2 K$ e) L* x; z2 S# o - print(lq.get())( l/ d: u3 r& L2 o6 R: N
- 8 `" Q2 x$ G" e' ]9 O# K
- print("-------------queue.PriorityQueue----------------")
, d! A! N% [3 n! [' s4 A - # 线程消息队列,PriorityQueue(优先级的队列:数字越小优先级越高)
# b0 e9 i9 w5 \; m `1 o4 t - pq = queue.PriorityQueue()
( @6 R+ l2 B: l V1 l+ N( B - pq.put((1, "Jet"))( A. e3 S3 Z( P* G1 s" z% p
- pq.put((3, "Jack"))
6 h9 ]3 y- u1 l9 T7 a0 J - pq.put((2, "Judy"))
1 u# |* |3 X0 c; E7 h7 B9 h4 _ - print(pq.get()). I% P5 ~: j: _4 U, [, {1 c$ L: ]
- print(pq.get()) K) L' D$ q( m5 |
- print(pq.get())
复制代码 |
-
-
7810.py
1002 Bytes, 下载次数: 36, 下载积分: 财富 -1 点
|