|
|
马上注册,结交更多好友,享用更多功能,让你轻松玩转新大榭论坛!
您需要 登录 才可以下载或查看,没有账号?注册
x
Python Queue 模块详解
& e, K. {3 n* W3 FPython3中队列是线程间最常用的交换数据的形式。Queue模块python3内置的标准模块,是提供队列操作的模块,虽然简单易用,但是不小心的话,还是会出现一些意外。 创建一个“队列”对象: \9 y$ Q6 o: Q/ B$ b9 B
import queue
7 H/ r* {% V! _q = queue.queue(maxsize = 10)7 s4 y3 k- g+ i {8 ?) M
queue.queue类即是一个队列的同步实现。队列长度可为无限或者有限。可通过queue的构造函数的可选参数maxsize来设定队列长度。如果maxsize小于1就表示队列长度无限。 将一个值放入队列中; W$ g, t+ `9 ^# X# X7 C
q.put(10)7 M0 N" Z- H/ V3 {$ c0 i
调用队列对象的put()方法在队尾插入一个项目。put()有两个参数,第一个item为必需的,为插入项目的值;第二个block为可选参数,默认为) P+ b( u+ P' a; S
1。如果队列当前为空且block为1,put()方法就使调用线程暂停,直到空出一个数据单元。如果block为0,put方法将引发Full异常。 将一个值从队列中取出
9 U$ ]* f5 B; `* X7 qq.get()
/ D- R1 ^$ C$ Q8 X( ]- u调用队列对象的get()方法从队头删除并返回一个项目。可选参数为block,默认为True。如果队列为空且block为True,get()就使调用线程暂停,直至有项目可用。如果队列为空且block为False,队列将引发Empty异常。 Python queue模块有三种队列及构造函数:+ J) G4 G6 D5 X! J6 X3 q
1、Python queue模块的FIFO队列先进先出。 class queue.queue(maxsize)
' a( }0 L t. k$ y+ m2、LIFO类似于堆,即先进后出。 class queue.Lifoqueue(maxsize)( D, N$ G# L3 p: A) ~3 E" q
3、还有一种是优先级队列级别越低越先出来。 class queue.Priorityqueue(maxsize) 此包中的常用方法(q =queue.queue()):
0 c! d: L: ?0 t2 M5 n& y3 F; g q.qsize() 返回队列的大小,即输出队列中元素的个数 q.queue.queue(5) 建立一个长度为5的队列q q.put(5) 将数字5入队 q.empty() 如果队列为空,返回True,反之False. J! U+ h/ Y; _+ {' i$ u7 o p4 W9 g
q.full() 如果队列满了,返回True,反之False: T- E- I# S B0 L8 m; ~5 R {
q.full 与 maxsize 大小对应
3 @+ D% ?+ o# S8 o9 |% K& C% _: `q.get([block[, timeout]]) 获取队列,timeout等待时间) A8 M: g) ^; c2 Y5 ^% b
q.get_nowait() 相当q.get(False)+ [: _5 T) R; f5 `8 o
非阻塞 q.put(item) 写入队列,timeout等待时间
) z0 c8 b. {8 Iq.put_nowait(item) 相当q.put(item, False)2 h3 n( L* V3 s/ N ]
q.task_done() 在完成一项工作之后,q.task_done() 函数向任务已经完成的队列发送一个信号
' B! n, v1 U2 L. r6 D0 V: j5 hq.join() 实际上意味着等到队列为空,再执行别的操作
% C/ T' H X& [) C8 k$ @2 m& D代码实例 7810
) P/ A$ `2 V+ O6 Q- import queue5 l1 W6 F) }) b
- + f" _/ z7 O4 ?' a1 |
- # 以下三个队列都可以设置最大长度maxsize,默认是无限大
. _1 \1 U* R9 @( D7 l6 j* | - print("-------------queue.Queue----------------")
0 m2 h1 W2 E8 o/ Y! Q- O5 b) T - # 线程消息队列,FIFO(先进先出)
2 a! |8 X" P4 H! g6 C - q = queue.Queue() j. ~! _$ g P% E9 t
- q.put("one")" [4 Z! Y! w# I- z
- q.put("two")
/ D1 X n- c1 i0 E* o) N) h - q.put("three")
5 Q3 p, c! H2 }# G( j - print(q.get())
7 ^0 J$ ?) m9 k5 O, H - print(q.get())2 @, ]. s2 T V: k3 `
- print(q.get())& l+ K$ g9 M4 g, x0 v# g$ Z# h1 w
- try:
`* }/ x7 w- v; i - # 队列中没有数据, 会阻塞。6 {' C! f( V- j7 L' i
- # 阻塞时间到了还没有数据 抛出 queue.Empty 异常 X: t% `+ p* g, Y# Y/ O) ^+ K6 r2 ]
- print(q.get(timeout=3))
; i( g: I* ~7 K8 Y( ^4 x - except queue.Empty as q_e:8 B4 V8 ~+ i7 N! a) V7 n: u- o
- print('queue empty')5 r5 j* H. K( O% k# d
-
. I6 @" c5 J) s. a+ M2 S - print("-------------queue.LifoQueue----------------")
, y6 A0 W1 I6 u( ]- u - # 线程消息队列,LIFO(后进先出)
4 U. L ~& M+ }4 t0 m F - lq = queue.LifoQueue()2 E! k1 q' E9 j% ~
- lq.put("one"); |" U; k, y( E/ T2 D# o0 K
- lq.put("two")" Z. M! n4 u) a1 v0 M% V7 r" x
- lq.put("three")
3 M: ~" u* U" N) [4 M - print(lq.get())
- z1 f6 r2 K5 @8 h - print(lq.get())( @, p# ~3 g4 E: t+ w5 n
- print(lq.get())1 f% Y" {) q$ ?/ X4 ]; F) e
-
7 e! f6 `" p4 V1 U4 N) V - print("-------------queue.PriorityQueue----------------")
; W+ e& T1 U% ?: l1 ?8 W - # 线程消息队列,PriorityQueue(优先级的队列:数字越小优先级越高)4 k: E) u% c; ^; ?+ p" Q7 P
- pq = queue.PriorityQueue()2 R% {2 `* [% C# W2 G
- pq.put((1, "Jet"))
3 Q3 |8 N$ Q$ J6 q) z. T0 w - pq.put((3, "Jack"))
: s9 ]) p2 i% j9 @: r- M - pq.put((2, "Judy"))
0 H1 @! X- ]" T' X- n! ~ - print(pq.get()); N f: a- n1 w" Y, e/ t; y1 X. m% m/ n
- print(pq.get())* p2 F# t9 ]. P6 S
- print(pq.get())
复制代码 |
-
-
7810.py
1002 Bytes, 下载次数: 36, 下载积分: 财富 -1 点
|