|
|
马上注册,结交更多好友,享用更多功能,让你轻松玩转新大榭论坛!
您需要 登录 才可以下载或查看,没有账号?注册
x
Python Queue 模块详解3 P* f" J' x7 I5 q/ A. Q) S2 O
Python3中队列是线程间最常用的交换数据的形式。Queue模块python3内置的标准模块,是提供队列操作的模块,虽然简单易用,但是不小心的话,还是会出现一些意外。 创建一个“队列”对象
9 c1 L& ~9 M6 Qimport queue
& u- k+ O1 V7 \& n% |; Mq = queue.queue(maxsize = 10)# A8 W% _# f" j' ]1 q A( T$ o
queue.queue类即是一个队列的同步实现。队列长度可为无限或者有限。可通过queue的构造函数的可选参数maxsize来设定队列长度。如果maxsize小于1就表示队列长度无限。 将一个值放入队列中5 Z$ b* L2 n% s+ @; {7 c
q.put(10)" M) E6 O) e9 @9 P; C% F+ l
调用队列对象的put()方法在队尾插入一个项目。put()有两个参数,第一个item为必需的,为插入项目的值;第二个block为可选参数,默认为0 g9 `4 r. Y& O& R5 J5 \
1。如果队列当前为空且block为1,put()方法就使调用线程暂停,直到空出一个数据单元。如果block为0,put方法将引发Full异常。 将一个值从队列中取出
' b. g; ~4 Q2 Q0 @* o; [4 y$ Dq.get()2 F5 H! d* |; y& C2 H. ^
调用队列对象的get()方法从队头删除并返回一个项目。可选参数为block,默认为True。如果队列为空且block为True,get()就使调用线程暂停,直至有项目可用。如果队列为空且block为False,队列将引发Empty异常。 Python queue模块有三种队列及构造函数:
& @) M+ l: A: y* R, M/ A1、Python queue模块的FIFO队列先进先出。 class queue.queue(maxsize)2 h0 H$ C) }( O, a- M8 i
2、LIFO类似于堆,即先进后出。 class queue.Lifoqueue(maxsize)- K3 N; h% S v2 w
3、还有一种是优先级队列级别越低越先出来。 class queue.Priorityqueue(maxsize) 此包中的常用方法(q =queue.queue()):
, S- B+ a# g: F4 y9 } q.qsize() 返回队列的大小,即输出队列中元素的个数 q.queue.queue(5) 建立一个长度为5的队列q q.put(5) 将数字5入队 q.empty() 如果队列为空,返回True,反之False1 T. o) m/ J1 q* ^, F
q.full() 如果队列满了,返回True,反之False
0 {! u) m& F6 p0 N# tq.full 与 maxsize 大小对应9 x: ]& Z& e% ?. n. w. L# J0 i
q.get([block[, timeout]]) 获取队列,timeout等待时间. Q$ z+ \* Q+ P9 v
q.get_nowait() 相当q.get(False)6 _3 D7 t B, O5 W
非阻塞 q.put(item) 写入队列,timeout等待时间
. c/ t0 J6 k* o; F2 e) lq.put_nowait(item) 相当q.put(item, False)
5 X9 L7 W/ a6 n6 v( C9 h* v- Wq.task_done() 在完成一项工作之后,q.task_done() 函数向任务已经完成的队列发送一个信号* R" U# ?. C, [% G- Z: _! F5 V
q.join() 实际上意味着等到队列为空,再执行别的操作
% f" g( m+ p3 r3 P; \" c) n/ O
代码实例 7810! m, U, B) P) x# T" M% G( q# A
- import queue; t6 @# j' C0 {3 \$ g3 L& e6 G& h
- 6 K- \( g1 b( N
- # 以下三个队列都可以设置最大长度maxsize,默认是无限大; _& K6 V) L4 U3 F( Z, t4 y
- print("-------------queue.Queue----------------")
! q) x8 Y! ?/ J+ o1 W2 K; E - # 线程消息队列,FIFO(先进先出)* @, R$ ?" j' ~
- q = queue.Queue()
" B2 J9 l) l/ I# c - q.put("one"), h" ]% r* S+ s$ }5 j6 ~8 v
- q.put("two")* s1 m% [6 Q# {" n. y
- q.put("three")- R5 j2 Z7 o& P
- print(q.get())
/ a9 c3 _; b* F7 A' ^ - print(q.get())4 D! ^) \0 ?: {) a' y0 d9 k% L
- print(q.get())5 S* E/ H% k4 A o$ L R# \
- try:
" T; J8 O' e# t$ A) T5 p/ n5 a - # 队列中没有数据, 会阻塞。
: R9 ~6 p7 \1 X P, O - # 阻塞时间到了还没有数据 抛出 queue.Empty 异常3 R" S+ V9 J! S9 z7 |7 C- L
- print(q.get(timeout=3))6 R+ e# d6 D; |0 k! G3 a
- except queue.Empty as q_e:
3 m) b6 N3 }: U9 l& v3 q - print('queue empty')) I2 W3 c7 O3 [. V6 o: k( l7 b* p
-
0 l) e/ m8 a! [. `! O; f: V6 K - print("-------------queue.LifoQueue----------------")4 i) P# l4 r& W
- # 线程消息队列,LIFO(后进先出)5 [2 T5 \9 C5 b; I* R7 l& Z
- lq = queue.LifoQueue(): m6 u2 B9 ?- H
- lq.put("one")- f9 S. N+ {+ {
- lq.put("two")& |% x- @8 }( D8 r: T
- lq.put("three")- ]; Y# c3 Y& K9 e ]/ W: X
- print(lq.get()), ^- j |" R4 g% B! N
- print(lq.get())) D# p8 o2 M. Z H
- print(lq.get()). A& n2 h9 f1 M+ z1 i$ c
- % o( g% d* g; }+ ^
- print("-------------queue.PriorityQueue----------------")3 a: ^, [9 h G+ v, l- P1 U
- # 线程消息队列,PriorityQueue(优先级的队列:数字越小优先级越高)
5 e# O2 z. ~( T; G) b: p - pq = queue.PriorityQueue()
7 V8 y# c9 ? g: q' {1 m2 L - pq.put((1, "Jet")), _# n% O g! ]
- pq.put((3, "Jack"))# w: g: o1 q' N$ O
- pq.put((2, "Judy"))
$ _. W- g& G d2 y1 ^7 e: t! ^ - print(pq.get())5 w+ p. ]# z* k3 L1 i9 w9 U$ k4 ]
- print(pq.get())
7 a* l+ u0 T5 g! I9 k. T" x: ` - print(pq.get())
复制代码 |
-
-
7810.py
1002 Bytes, 下载次数: 36, 下载积分: 财富 -1 点
|