|
|
马上注册,结交更多好友,享用更多功能,让你轻松玩转新大榭论坛!
您需要 登录 才可以下载或查看,没有账号?注册
x
Python Queue 模块详解/ x( {8 f7 c& G* W4 v
Python3中队列是线程间最常用的交换数据的形式。Queue模块python3内置的标准模块,是提供队列操作的模块,虽然简单易用,但是不小心的话,还是会出现一些意外。 创建一个“队列”对象7 m! }$ P% x: z9 x; Z
import queue) s0 y7 @6 p7 }. m+ `
q = queue.queue(maxsize = 10)* T, W) k' z W+ w" X
queue.queue类即是一个队列的同步实现。队列长度可为无限或者有限。可通过queue的构造函数的可选参数maxsize来设定队列长度。如果maxsize小于1就表示队列长度无限。 将一个值放入队列中
0 |6 L+ Q" J7 a" A8 _5 W9 v% c4 q6 Z3 n# hq.put(10)
; E% `6 r# F: q, B" a1 Z调用队列对象的put()方法在队尾插入一个项目。put()有两个参数,第一个item为必需的,为插入项目的值;第二个block为可选参数,默认为
' Z) P* d% C. E% K2 J9 e. v* H, V1。如果队列当前为空且block为1,put()方法就使调用线程暂停,直到空出一个数据单元。如果block为0,put方法将引发Full异常。 将一个值从队列中取出
+ e8 R3 V9 W8 A$ cq.get()3 ~- C# ~5 D$ H
调用队列对象的get()方法从队头删除并返回一个项目。可选参数为block,默认为True。如果队列为空且block为True,get()就使调用线程暂停,直至有项目可用。如果队列为空且block为False,队列将引发Empty异常。 Python queue模块有三种队列及构造函数:
1 O. o3 q9 g6 Y( r+ R8 I8 h1、Python queue模块的FIFO队列先进先出。 class queue.queue(maxsize). J( ]% m4 C: Q; l, x
2、LIFO类似于堆,即先进后出。 class queue.Lifoqueue(maxsize); U( G9 E9 s( o9 \! I
3、还有一种是优先级队列级别越低越先出来。 class queue.Priorityqueue(maxsize) 此包中的常用方法(q =queue.queue()):7 r* I) D0 k0 L; B
q.qsize() 返回队列的大小,即输出队列中元素的个数 q.queue.queue(5) 建立一个长度为5的队列q q.put(5) 将数字5入队 q.empty() 如果队列为空,返回True,反之False
6 d5 o% s) d# Y+ X- u- ?q.full() 如果队列满了,返回True,反之False
' T$ ]8 \7 [9 B/ @6 F; ^) c/ Nq.full 与 maxsize 大小对应
: M( x' O- a1 H% _q.get([block[, timeout]]) 获取队列,timeout等待时间" S" B6 p3 w: @5 f" j
q.get_nowait() 相当q.get(False)
3 ~1 ?* w! D4 G' }* f非阻塞 q.put(item) 写入队列,timeout等待时间) {- X$ Z' M, K6 o1 ?
q.put_nowait(item) 相当q.put(item, False)
4 j4 N$ ?* J7 y) j1 Z c( M5 Bq.task_done() 在完成一项工作之后,q.task_done() 函数向任务已经完成的队列发送一个信号
: ^: M6 X* W6 H4 fq.join() 实际上意味着等到队列为空,再执行别的操作
4 A7 s" p& E# Q5 Y
代码实例 7810
( S" A3 ]0 R/ q( N# B& s- import queue1 _! Y H5 [; B( S8 X
- , X5 s0 |5 X' {$ E4 F2 e
- # 以下三个队列都可以设置最大长度maxsize,默认是无限大
; \( d. W$ M: N# u$ X/ u - print("-------------queue.Queue----------------")9 O# f# c# j# |+ _
- # 线程消息队列,FIFO(先进先出)% } I I1 ]! @' K2 x6 j
- q = queue.Queue()
* |: y- p" d6 [! I+ F3 ` n+ s - q.put("one")& w0 z# g# m! E2 Q4 a) e
- q.put("two")% g! Z2 | Z/ |' ^& Y; D
- q.put("three")
4 t8 M# O8 T2 U2 `2 W8 V, { - print(q.get())
) ?) z" C) k' L8 U+ h8 r - print(q.get())- F+ k1 |* `1 [( G% y% ]+ s7 Q
- print(q.get())
6 R/ A/ O6 q, _5 [3 B - try:
2 d* q$ W4 g3 {5 M K - # 队列中没有数据, 会阻塞。
3 N' t2 O h: s9 x - # 阻塞时间到了还没有数据 抛出 queue.Empty 异常
+ C4 m$ D% w" Z& ?+ U - print(q.get(timeout=3))) I! _% W5 K& H7 t
- except queue.Empty as q_e:
. v7 f' `6 L9 B. [5 V0 I8 [* y - print('queue empty')
& L/ {* K. x% F# E/ ]1 q" N2 }7 d -
; |) V* w! X) D w - print("-------------queue.LifoQueue----------------"); l* G/ d. g. R* \: s
- # 线程消息队列,LIFO(后进先出)
* T% ^: S/ t2 G' H* I5 _ - lq = queue.LifoQueue()
/ L* A" z4 I( Y9 ?( N - lq.put("one")
* u; B0 W/ J0 K1 e - lq.put("two")% L0 G" G' Y4 j9 W4 _8 E- l
- lq.put("three")
" u* h' u' c$ ?' ?! ` - print(lq.get())$ G! B+ l `+ k. L
- print(lq.get())3 s, m5 Y/ P) G5 `: E
- print(lq.get())
* @" D+ C; V l. N$ Z& \) J - 6 v. P" I& N2 {2 y' t2 v( B3 N$ b3 Y
- print("-------------queue.PriorityQueue----------------")
* y/ X* E M1 i6 m - # 线程消息队列,PriorityQueue(优先级的队列:数字越小优先级越高)
9 G" @7 G' U" y9 N4 ^1 q, `) ` - pq = queue.PriorityQueue()
' f2 V8 O! Z* _. _2 C - pq.put((1, "Jet"))! |1 e# ~+ a7 `) P0 I4 e
- pq.put((3, "Jack"))
' l5 Q7 l' K; U - pq.put((2, "Judy")), {1 b8 {; Y% C v2 n& d) `
- print(pq.get())
8 Y/ m- ?6 m- W' a3 F7 a - print(pq.get())$ f- l) ~& A# m( u3 _( l
- print(pq.get())
复制代码 |
-
-
7810.py
1002 Bytes, 下载次数: 36, 下载积分: 财富 -1 点
|