小编给大家分享一下Python中线程安全队列Queue的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
像排队一样,从头到尾排成一排,还可以有人继续往后排队,这就是队列。
这里学委想说的是Queue
这个类, 它是queue
这个内置模块内的一个类。
import queue q = queue.Queue(5) #可以传入参数指定队列大小 queue.Queue()# 不传或者给0或者<0的数字则创建一个无限长度的队列
它提供了很多函数,下面几个函数,我们使用的比较多:
get
: 获取并移除队头元素,就是出队
put
: 往队列末尾加入元素,也就是后来者排队
qsize
: 获取队列的长度
empty
: 队列空了,没有人在排了
full
: 队列满了。
看着比较枯燥,学委画了下图展示:
这个队列put了3次,依次放入:持续学习,持续开发,我雷学委。队列长度为3
准备了下面的代码:
import queue q = queue.Queue(5) print("学委粉丝队列:", q) print("空队,学委粉丝队列大小:", q.qsize()) print("空队列?", q.empty()) for i in range(5): q.put(i) print("队列满了?", q.full()) print("排满了,学委粉丝队列大小:", q.qsize()) while not q.empty(): print("粉丝 %s 出队点赞!" % q.get()) print("最后,学委粉丝队列大小:", q.qsize())
这段代码创建了一个长的为5的队列。
然后一个循环写满队列,接着再依此出队,粉丝出队点赞。
下面是运行效果:
是不是很简单。
前面几篇文章,碰到下面的代码(反复读写共享变量)结果总是出乎依赖!
amount = 100 def transfer(money): global amount for i in range(100000): amount += money
如果我们对队列进行反复读写,会不会出现问题呢?
不妨,写个代码验收一下:
import queue import threading xuewei_fans_q = queue.Queue() def transfer(money): for i in range(100000): xuewei_fans_q.put(money) xuewei_fans_q.get() # 创建4个任务重复给学委加关注/脱粉(还是希望各位编程的明日之星跟着学习,共同进步!) t_group = [] for i in range(10): t = threading.Thread(target=lambda: transfer(-1)) t_group.append(t) t.start() t = threading.Thread(target=lambda: transfer(1)) t_group.append(t) t.start() t = threading.Thread(target=lambda: transfer(-1)) t_group.append(t) t.start() t = threading.Thread(target=lambda: transfer(1)) t_group.append(t) t.start() for t in t_group: t.join() print("-" * 16) print("活跃线程数:", threading.active_count()) print("活跃线程:", threading.current_thread().name) #反复对队列进行添加数据,移除数据,队列最后清零了 print("学委粉丝队列:", xuewei_fans_q.qsize())
不管运行多少次,队列(希望是黑粉队列)都为0元素。
看完了这篇文章,相信你对“Python中线程安全队列Queue的示例分析”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。