|
|
马上注册,结交更多好友,享用更多功能,让你轻松玩转新大榭论坛!
您需要 登录 才可以下载或查看,没有账号?注册
x
Python Queue 模块详解
0 @+ r2 g9 p, z9 VPython3中队列是线程间最常用的交换数据的形式。Queue模块python3内置的标准模块,是提供队列操作的模块,虽然简单易用,但是不小心的话,还是会出现一些意外。 创建一个“队列”对象
- U2 K7 t8 h B6 s3 G$ N# ?import queue
1 I; e; p( r6 j; `# u0 ]q = queue.queue(maxsize = 10)# }: O4 @( v3 z, k1 I
queue.queue类即是一个队列的同步实现。队列长度可为无限或者有限。可通过queue的构造函数的可选参数maxsize来设定队列长度。如果maxsize小于1就表示队列长度无限。 将一个值放入队列中
/ w/ T2 o# K% Kq.put(10)
8 k; y, Q/ X+ b" v' O9 P调用队列对象的put()方法在队尾插入一个项目。put()有两个参数,第一个item为必需的,为插入项目的值;第二个block为可选参数,默认为
& |0 m# N4 [9 u! U& ~ L) n0 U* O) f1。如果队列当前为空且block为1,put()方法就使调用线程暂停,直到空出一个数据单元。如果block为0,put方法将引发Full异常。 将一个值从队列中取出
6 X2 ?3 Q4 }' T( Uq.get()# t- n2 G; v n
调用队列对象的get()方法从队头删除并返回一个项目。可选参数为block,默认为True。如果队列为空且block为True,get()就使调用线程暂停,直至有项目可用。如果队列为空且block为False,队列将引发Empty异常。 Python queue模块有三种队列及构造函数:% b9 n Z9 w/ q5 C" C
1、Python queue模块的FIFO队列先进先出。 class queue.queue(maxsize)
* w |3 j- f3 M) u# r2、LIFO类似于堆,即先进后出。 class queue.Lifoqueue(maxsize)
2 I0 s+ d2 l# _& ]6 O3、还有一种是优先级队列级别越低越先出来。 class queue.Priorityqueue(maxsize) 此包中的常用方法(q =queue.queue()):. ]: g$ W, _9 M% j S
q.qsize() 返回队列的大小,即输出队列中元素的个数 q.queue.queue(5) 建立一个长度为5的队列q q.put(5) 将数字5入队 q.empty() 如果队列为空,返回True,反之False E3 s' O/ o3 h( A
q.full() 如果队列满了,返回True,反之False
0 C9 K1 Y3 U; U9 n6 uq.full 与 maxsize 大小对应. F- S! F! G9 l& Y* A/ l
q.get([block[, timeout]]) 获取队列,timeout等待时间 L+ P# [& w2 S: W9 o* ?+ J$ K
q.get_nowait() 相当q.get(False)4 T9 A$ [: G- F& \
非阻塞 q.put(item) 写入队列,timeout等待时间7 |. r* I7 T5 }% U) }: u) n
q.put_nowait(item) 相当q.put(item, False)0 R$ a% B1 _, u, q8 o# @) z: m! Y& x
q.task_done() 在完成一项工作之后,q.task_done() 函数向任务已经完成的队列发送一个信号
+ O% w: r. I6 M9 Tq.join() 实际上意味着等到队列为空,再执行别的操作
2 C V, `3 _% s- J. Z' {; w' {, s代码实例 78107 ~. r8 N7 z( }5 w
- import queue
1 [+ I" S( b0 g/ T; S$ Q -
- H: g; p: l" a. {* t a - # 以下三个队列都可以设置最大长度maxsize,默认是无限大
2 k; H# s v4 H3 }+ n8 J" h - print("-------------queue.Queue----------------")
# V8 A0 r& W& K" Q - # 线程消息队列,FIFO(先进先出)5 l# l* t! j! T3 I S
- q = queue.Queue()( v9 B5 W p3 t% u$ U
- q.put("one")
# U# x! _; G: L - q.put("two")
5 e: J, q: m4 e7 ~$ T - q.put("three")3 g& O3 N3 w' [ `$ p
- print(q.get()). ^7 \0 ~6 T2 j Z
- print(q.get())$ o$ s, y7 F! P D. g! l& V
- print(q.get())
/ j; `/ t" ^0 `: z8 T9 o - try:
$ Q9 ]% d8 S: r1 ]+ j j$ D - # 队列中没有数据, 会阻塞。
, H/ u6 {& d1 t- T - # 阻塞时间到了还没有数据 抛出 queue.Empty 异常
3 ~, F6 P/ a9 j- }+ s! C( k" U( B - print(q.get(timeout=3))' k, r' L& \, O
- except queue.Empty as q_e:$ E0 n% V. w" `, C/ x
- print('queue empty')
' o1 C) h: A& w: j2 @& |2 I8 ` - + W! c8 s. w5 s) W
- print("-------------queue.LifoQueue----------------")" z( b! B; h! V& A/ D: a
- # 线程消息队列,LIFO(后进先出)
& f/ q4 A# ^* V" z3 u - lq = queue.LifoQueue()8 R- z- t8 @& g5 O
- lq.put("one")
2 j) }9 [: L6 j H0 j1 e7 b- ^ - lq.put("two")2 l: L6 F7 A. H ?7 Z Z
- lq.put("three")3 h6 ?) R9 n! T9 f' }
- print(lq.get())
6 y a( G# s/ t- Q - print(lq.get())$ `& m) j# F0 R0 v2 _2 j
- print(lq.get()) i" Y$ o* K, W/ z9 O* j# U
-
0 i" G: P+ ]; x# ~3 u6 x5 O; p1 W/ ^ - print("-------------queue.PriorityQueue----------------")
6 t; x% ^0 W% ^' ` - # 线程消息队列,PriorityQueue(优先级的队列:数字越小优先级越高)
) f2 |) j$ t8 C; H+ V/ e - pq = queue.PriorityQueue()
& J3 f" e7 j8 `3 U - pq.put((1, "Jet"))! m9 x7 y; g) ^
- pq.put((3, "Jack"))! _! M/ e5 U% k! x
- pq.put((2, "Judy")): V8 ~' X. F- s* x4 o/ Y* \% V, q
- print(pq.get())
3 n) J4 m `$ ?( i, a4 m$ A0 Y0 ~9 D - print(pq.get())9 @# J0 e; M# G3 @4 e. e G' ~; _
- print(pq.get())
复制代码 |
-
-
7810.py
1002 Bytes, 下载次数: 36, 下载积分: 财富 -1 点
|