小编给大家分享一下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的示例分析”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。