|
|
马上注册,结交更多好友,享用更多功能,让你轻松玩转新大榭论坛!
您需要 登录 才可以下载或查看,没有账号?注册
x
Python Queue 模块详解
% H" P# I4 X- r. F6 aPython3中队列是线程间最常用的交换数据的形式。Queue模块python3内置的标准模块,是提供队列操作的模块,虽然简单易用,但是不小心的话,还是会出现一些意外。 创建一个“队列”对象" j5 Y, n9 H1 O$ ~( J! @
import queue" n3 I0 |% Y- ?& V. s
q = queue.queue(maxsize = 10)
+ E% g+ k4 D& A! K0 Oqueue.queue类即是一个队列的同步实现。队列长度可为无限或者有限。可通过queue的构造函数的可选参数maxsize来设定队列长度。如果maxsize小于1就表示队列长度无限。 将一个值放入队列中
: \+ i( X. b$ N& p, h3 c. W- mq.put(10)% l) a5 S% p9 p! Q! p7 w$ c
调用队列对象的put()方法在队尾插入一个项目。put()有两个参数,第一个item为必需的,为插入项目的值;第二个block为可选参数,默认为0 U1 n) ~' W& @! P0 s/ h. U$ d
1。如果队列当前为空且block为1,put()方法就使调用线程暂停,直到空出一个数据单元。如果block为0,put方法将引发Full异常。 将一个值从队列中取出
& _ R0 Q3 \! ?( I" z( J+ H: Tq.get()6 a. a; D, v! g; O5 p/ W Z9 F
调用队列对象的get()方法从队头删除并返回一个项目。可选参数为block,默认为True。如果队列为空且block为True,get()就使调用线程暂停,直至有项目可用。如果队列为空且block为False,队列将引发Empty异常。 Python queue模块有三种队列及构造函数:$ f# M: e6 x, T0 u
1、Python queue模块的FIFO队列先进先出。 class queue.queue(maxsize)3 |. H# m& `( w8 D# P
2、LIFO类似于堆,即先进后出。 class queue.Lifoqueue(maxsize): t$ K1 T# z4 `
3、还有一种是优先级队列级别越低越先出来。 class queue.Priorityqueue(maxsize) 此包中的常用方法(q =queue.queue()):& a# n, \/ H# x% W1 a0 x
q.qsize() 返回队列的大小,即输出队列中元素的个数 q.queue.queue(5) 建立一个长度为5的队列q q.put(5) 将数字5入队 q.empty() 如果队列为空,返回True,反之False; z# w) S0 `2 Y! v8 L
q.full() 如果队列满了,返回True,反之False1 j, {' {9 W& r$ L! } u2 `# ~
q.full 与 maxsize 大小对应
. n- `: W8 m8 x& y6 f( L" D) zq.get([block[, timeout]]) 获取队列,timeout等待时间
0 q2 E3 z! R+ e% rq.get_nowait() 相当q.get(False)! Q) B$ T% A" Z' J1 `, z4 Q
非阻塞 q.put(item) 写入队列,timeout等待时间" q5 ~5 q5 ]) ~" _
q.put_nowait(item) 相当q.put(item, False)
- {* C+ h1 j* V; c& rq.task_done() 在完成一项工作之后,q.task_done() 函数向任务已经完成的队列发送一个信号! R+ s6 ]- ?1 A* O' q! D
q.join() 实际上意味着等到队列为空,再执行别的操作
/ I* q" I& J* G1 j% b& Z L
代码实例 7810
- u2 ]/ h4 q. A2 ~- import queue% ?3 ^' Q0 X( }( f* ]5 O
-
6 o- \9 k7 k+ A - # 以下三个队列都可以设置最大长度maxsize,默认是无限大
: ^" ` l1 d5 L6 X/ O# \ - print("-------------queue.Queue----------------")
2 E; Z/ O8 M+ _2 B! N X - # 线程消息队列,FIFO(先进先出)' q; w% f" r4 W! `1 C/ y9 w
- q = queue.Queue()5 c5 w- ?" r' E
- q.put("one")1 w# w$ u/ H: X& A3 l8 y3 `
- q.put("two"). y7 F& |' d! i/ ` j; g2 S; R; o
- q.put("three")
5 {; U5 m4 o* Z3 N- n - print(q.get())
) ]' V7 X& B% ?( b/ L - print(q.get())# } H: J9 q* r
- print(q.get())
" }6 g4 M C7 Q* J- g/ N% U! \" P - try:
6 U3 c& g3 I$ a - # 队列中没有数据, 会阻塞。
! X$ x. q) H+ p: |& M3 I - # 阻塞时间到了还没有数据 抛出 queue.Empty 异常
; a4 M1 W6 r1 n( Z- X - print(q.get(timeout=3))
, n' Q1 _3 u1 h1 n. Z - except queue.Empty as q_e:+ k+ J; s( Q3 }
- print('queue empty')7 }# Q4 w# S: l* X3 }0 u3 s
-
/ r% l0 D; _: [- L' T. x3 a1 U - print("-------------queue.LifoQueue----------------"): _% B6 ]* l9 B3 C. q1 r6 h
- # 线程消息队列,LIFO(后进先出)9 O, ^" C5 M+ K9 A- c/ B& y/ R' ~
- lq = queue.LifoQueue()
a# _: m) A- M0 h6 ?' R - lq.put("one")
3 j6 k0 n4 K8 A% p - lq.put("two")
: i+ ^' C; R8 j - lq.put("three")* X+ Q* D5 }' z$ D
- print(lq.get())
. `# N. J: f6 [, p* m: m; n - print(lq.get())
+ y5 t' P, g8 A( s( y' ~, Z - print(lq.get())
' _& D/ B" `7 X T R' o( h - 4 l/ O# B h' i o1 L
- print("-------------queue.PriorityQueue----------------")
% y' D, c% r4 j! K8 h1 q3 p - # 线程消息队列,PriorityQueue(优先级的队列:数字越小优先级越高). m8 t) r3 D+ ?
- pq = queue.PriorityQueue()6 S9 i' R$ Z* Q
- pq.put((1, "Jet"))) F6 X3 r: M6 L9 I$ N
- pq.put((3, "Jack"))
( R) L! ^7 ?& W L; u! O) ^ - pq.put((2, "Judy")): _7 [ r9 Q; z5 N, m4 l# P
- print(pq.get()), D7 t1 C, D1 L# J/ @
- print(pq.get())8 l5 G# R A, b0 e
- print(pq.get())
复制代码 |
-
-
7810.py
1002 Bytes, 下载次数: 36, 下载积分: 财富 -1 点
|