|
|
马上注册,结交更多好友,享用更多功能,让你轻松玩转新大榭论坛!
您需要 登录 才可以下载或查看,没有账号?注册
x
Python Queue 模块详解8 N; J7 b! h2 b9 B7 C& d8 T
Python3中队列是线程间最常用的交换数据的形式。Queue模块python3内置的标准模块,是提供队列操作的模块,虽然简单易用,但是不小心的话,还是会出现一些意外。 创建一个“队列”对象& b3 i4 w* C3 h! {0 Z* |
import queue& Z, K& Z/ K( r) f# d5 J0 i
q = queue.queue(maxsize = 10)
0 J+ ?( c$ Z, V/ U$ e( L' w9 Q2 {queue.queue类即是一个队列的同步实现。队列长度可为无限或者有限。可通过queue的构造函数的可选参数maxsize来设定队列长度。如果maxsize小于1就表示队列长度无限。 将一个值放入队列中
" `4 g; s) _0 S8 P9 Q' Dq.put(10)
; {' O H# d& ^: V: H调用队列对象的put()方法在队尾插入一个项目。put()有两个参数,第一个item为必需的,为插入项目的值;第二个block为可选参数,默认为) e& x+ h7 t1 n' N' ?! s: B1 ^
1。如果队列当前为空且block为1,put()方法就使调用线程暂停,直到空出一个数据单元。如果block为0,put方法将引发Full异常。 将一个值从队列中取出( d0 r( g* I) S) D6 r4 P" R% R
q.get()8 Z4 K' [6 b; o
调用队列对象的get()方法从队头删除并返回一个项目。可选参数为block,默认为True。如果队列为空且block为True,get()就使调用线程暂停,直至有项目可用。如果队列为空且block为False,队列将引发Empty异常。 Python queue模块有三种队列及构造函数:# i. F% s8 T4 ^
1、Python queue模块的FIFO队列先进先出。 class queue.queue(maxsize)
* o- ]6 g2 Z) c/ A1 \2、LIFO类似于堆,即先进后出。 class queue.Lifoqueue(maxsize): G# G3 T& T6 v1 z" o5 [6 x8 ]& [
3、还有一种是优先级队列级别越低越先出来。 class queue.Priorityqueue(maxsize) 此包中的常用方法(q =queue.queue()):; K* W& b* Z1 Z& W
q.qsize() 返回队列的大小,即输出队列中元素的个数 q.queue.queue(5) 建立一个长度为5的队列q q.put(5) 将数字5入队 q.empty() 如果队列为空,返回True,反之False- o9 w, U' X( M3 f8 D
q.full() 如果队列满了,返回True,反之False
# [5 Z9 v' W Jq.full 与 maxsize 大小对应
3 O3 ]1 A9 z5 [q.get([block[, timeout]]) 获取队列,timeout等待时间
6 V5 G& L4 w7 V% j/ d: D" I1 Jq.get_nowait() 相当q.get(False)
) c' g! Y( J% W5 p9 j2 n& k' \非阻塞 q.put(item) 写入队列,timeout等待时间2 i& ]& Y! S& W/ K* J5 f- W9 @
q.put_nowait(item) 相当q.put(item, False)1 Q8 S3 C- e# R+ c9 T. o
q.task_done() 在完成一项工作之后,q.task_done() 函数向任务已经完成的队列发送一个信号
2 l, |0 @4 L' l* mq.join() 实际上意味着等到队列为空,再执行别的操作
% I# g" O1 b4 d# T代码实例 7810
|2 h" z0 T4 n! |- Q4 c- import queue1 \1 a$ ^: N3 W8 S8 N% q2 A
-
6 R o. C$ {' V& ~3 h' w - # 以下三个队列都可以设置最大长度maxsize,默认是无限大* u) |% |0 S; }) i u7 Y
- print("-------------queue.Queue----------------")
$ G: Y6 \" j/ g8 t2 |% M - # 线程消息队列,FIFO(先进先出)
% Z4 }/ P, o! ]0 ]0 D& D9 ` - q = queue.Queue()( ]4 ?& @9 _7 R
- q.put("one")
0 x% Z+ T) R" |3 q) I - q.put("two")/ Y' H2 X1 {2 j+ u* t6 h3 Z
- q.put("three"), q8 d& L# L1 y! u5 u
- print(q.get())
+ J: x4 Z: }* H& \) j - print(q.get()). b+ k, O: R4 \
- print(q.get())
2 p% p# {/ J: p - try:
6 y. @5 r' ?( Q0 S2 r - # 队列中没有数据, 会阻塞。
- G/ c2 d) e! Y4 i# @- C# r; Y - # 阻塞时间到了还没有数据 抛出 queue.Empty 异常
: D1 A5 ^. `% d+ {- f) U7 i - print(q.get(timeout=3))) [8 A. k3 x: G3 s
- except queue.Empty as q_e:
! s" f+ p; H4 p& k' X - print('queue empty'); I3 F/ Z& k5 U1 A! `
- * b7 J; K: [! W* {
- print("-------------queue.LifoQueue----------------")
$ C: F" `' ~) z& g - # 线程消息队列,LIFO(后进先出)1 k7 ?5 @1 V) k$ X6 M
- lq = queue.LifoQueue()5 n1 ~: G% m _) ] n# Z
- lq.put("one")
; e6 @1 v- C( n6 f0 ?( e - lq.put("two"). R; _+ g7 ]% i3 g
- lq.put("three")+ X! b5 ~0 }. o/ Y$ S% }: V
- print(lq.get())' Q# X! E% L0 w: q0 ]5 n$ J" m
- print(lq.get())
. `2 t E/ H: Z - print(lq.get()), V0 e% g8 p5 }- A. w* X$ C
- 1 a! w o2 D7 f6 ^4 r% I" {9 n
- print("-------------queue.PriorityQueue----------------")
* T& \ m+ F( a' h% L0 |/ S$ O - # 线程消息队列,PriorityQueue(优先级的队列:数字越小优先级越高)
, ~* C* h, b; W3 D% e2 @ - pq = queue.PriorityQueue()
. a! \5 t% c4 c) c8 y2 m - pq.put((1, "Jet"))
[) A: ^1 k- z/ b - pq.put((3, "Jack"))) G0 z E+ T. f5 c8 W8 n
- pq.put((2, "Judy"))- l0 @ e. v) b+ o; t9 n
- print(pq.get())
' G5 r0 {+ D9 B/ I+ Z% V2 T, c2 W. o - print(pq.get())9 v2 A* b2 z" ?2 S
- print(pq.get())
复制代码 |
-
-
7810.py
1002 Bytes, 下载次数: 36, 下载积分: 财富 -1 点
|