|
|
马上注册,结交更多好友,享用更多功能,让你轻松玩转新大榭论坛!
您需要 登录 才可以下载或查看,没有账号?注册
x
Python Queue 模块详解, f3 ?! D' Q: p# g7 I
Python3中队列是线程间最常用的交换数据的形式。Queue模块python3内置的标准模块,是提供队列操作的模块,虽然简单易用,但是不小心的话,还是会出现一些意外。 创建一个“队列”对象5 {( b" E( V( X1 `9 {; t" o# L
import queue( ~" W. l# X4 l
q = queue.queue(maxsize = 10)
" @0 b9 T& C8 _- Xqueue.queue类即是一个队列的同步实现。队列长度可为无限或者有限。可通过queue的构造函数的可选参数maxsize来设定队列长度。如果maxsize小于1就表示队列长度无限。 将一个值放入队列中
6 x: q6 r" e+ nq.put(10); {3 J- N1 j- a- T9 v6 y
调用队列对象的put()方法在队尾插入一个项目。put()有两个参数,第一个item为必需的,为插入项目的值;第二个block为可选参数,默认为+ u( g: d' O4 P" G( [
1。如果队列当前为空且block为1,put()方法就使调用线程暂停,直到空出一个数据单元。如果block为0,put方法将引发Full异常。 将一个值从队列中取出
) ]1 \' N" x/ f# Zq.get()
6 Z- G/ Q$ D9 _( k调用队列对象的get()方法从队头删除并返回一个项目。可选参数为block,默认为True。如果队列为空且block为True,get()就使调用线程暂停,直至有项目可用。如果队列为空且block为False,队列将引发Empty异常。 Python queue模块有三种队列及构造函数:( q) }6 r' K3 h2 E
1、Python queue模块的FIFO队列先进先出。 class queue.queue(maxsize)
5 W! R7 x' k; e! _4 E2、LIFO类似于堆,即先进后出。 class queue.Lifoqueue(maxsize)% Y3 n' q2 `9 v+ u ?0 h1 C1 d
3、还有一种是优先级队列级别越低越先出来。 class queue.Priorityqueue(maxsize) 此包中的常用方法(q =queue.queue()):
2 p! ~5 V- \+ c* l7 e# t: H; m q.qsize() 返回队列的大小,即输出队列中元素的个数 q.queue.queue(5) 建立一个长度为5的队列q q.put(5) 将数字5入队 q.empty() 如果队列为空,返回True,反之False2 E: a+ {6 c& n( `+ {
q.full() 如果队列满了,返回True,反之False; a% ]2 `5 _8 E2 r
q.full 与 maxsize 大小对应
8 m, t6 R! B* _) A' n. Pq.get([block[, timeout]]) 获取队列,timeout等待时间9 P( {9 M3 m- m! Z3 I# J# G. t4 b
q.get_nowait() 相当q.get(False)
6 R2 p4 X3 w7 ~. |% i h4 N3 i% ]非阻塞 q.put(item) 写入队列,timeout等待时间. n$ N, @/ u: o; K, L) I, ]
q.put_nowait(item) 相当q.put(item, False)
; J5 b# f* w( A; Hq.task_done() 在完成一项工作之后,q.task_done() 函数向任务已经完成的队列发送一个信号
* | F8 {) \+ f" Rq.join() 实际上意味着等到队列为空,再执行别的操作
0 p- `- B# Y$ j7 ?0 n" f
代码实例 7810
! _( v& }# }$ L* s: B; C9 X- import queue5 T6 a( ^' P3 C* G1 ]# x2 h
-
) d9 j! ~* D) Z - # 以下三个队列都可以设置最大长度maxsize,默认是无限大. _( T, Z7 v" v6 O7 u
- print("-------------queue.Queue----------------"); n) ~0 {# ~0 l2 F7 J! @1 s
- # 线程消息队列,FIFO(先进先出)6 M% X" A' z$ A/ }: ~$ A- N% @
- q = queue.Queue()# u, ^& I$ `* X" v( V
- q.put("one")
( c2 y% Y& |' S+ X: T- [! \/ ~ - q.put("two")
) `+ D2 r8 s7 p* x6 N5 a) L - q.put("three")6 W! @$ o4 h% D& M9 V
- print(q.get())8 o c7 r; k' G/ ?
- print(q.get()) f" Z+ V3 p# _8 _- P$ M: k( E' C
- print(q.get())# ]5 U3 T5 l z+ T4 b2 `
- try:
; w7 g3 T7 {4 @8 e1 j, ? - # 队列中没有数据, 会阻塞。/ E7 q8 T+ x h! k
- # 阻塞时间到了还没有数据 抛出 queue.Empty 异常
- J% ^ M: w8 Z2 ?: j, H - print(q.get(timeout=3))
3 F7 P+ v% J2 [7 Z( { - except queue.Empty as q_e:
% ]! }( U5 f6 O o( _+ t - print('queue empty'); {% t/ F G* Y3 ~2 T
- 2 o% V/ h/ x# l5 a# L7 V3 b' E. h
- print("-------------queue.LifoQueue----------------")
! y) O' f5 z* C; M- T - # 线程消息队列,LIFO(后进先出)9 z1 e( Y) w7 L' E( ]3 y& N
- lq = queue.LifoQueue()) N$ U' B+ ?9 {+ Y) i; {
- lq.put("one")6 B# G6 S: M! _1 D
- lq.put("two")1 O" C+ u5 u2 t$ [$ {7 `6 F6 E
- lq.put("three")
, ?+ g( H0 f, Q8 k; U* G- ^ - print(lq.get())
, L$ K; J2 l7 z$ h/ U$ |) H4 ` - print(lq.get())
) [) q# a- }' k - print(lq.get())- A& _; R9 y" H) J
- p& [. F$ p8 U0 N& [
- print("-------------queue.PriorityQueue----------------")- ?+ [+ a+ y/ [( k! ~# A8 ^' \
- # 线程消息队列,PriorityQueue(优先级的队列:数字越小优先级越高) J, g. Q$ k* c' [0 b( M8 C; r
- pq = queue.PriorityQueue()
! f& k( n# K2 q ]8 } - pq.put((1, "Jet"))
$ X0 U8 K; u8 ]- J8 ] - pq.put((3, "Jack"))3 z" H( i* j6 r8 [( l
- pq.put((2, "Judy"))
2 N+ Y( t4 n( ~% p7 n, ? - print(pq.get())
2 R' |/ `( m! b. w2 p - print(pq.get())& A, Q7 `/ l0 m4 ]# c# C* Z3 k
- print(pq.get())
复制代码 |
-
-
7810.py
1002 Bytes, 下载次数: 36, 下载积分: 财富 -1 点
|