前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >python的queue的简单使用

python的queue的简单使用

作者头像
灯珑LoGin
发布2022-10-31 09:31:49
2790
发布2022-10-31 09:31:49
举报
文章被收录于专栏:龙进的专栏龙进的专栏

在线程之间传递数据是很常见的事情。python中的Queue模块可以为我们自动控制线程锁,保证数据同步。

Queue类实现了一个基本的先进先出(FIFO)容器,使用put将元素添加到序列尾端,用get从序列中移除元素。

单线程的队列比较简单,就不提了。

这里写了一个例程,主要是将队列与多线程结合起来使用。

代码语言:javascript
复制
import queue
import threading
import time


#创建工作队列并限定队列的最大元素是10个
work_queue = queue.Queue(maxsize=10)

#创建结果队列并限制队列的最大元素是10个
result_queue = queue.Queue(maxsize=10)


class WorkThread(threading.Thread):
    def __init__(self, thread_id):
        super(WorkThread, self).__init__()
        self.thread_id = thread_id

    def run(self):
        while not work_queue.empty():
            work = work_queue.get()
            time.sleep(3)
            out = 'Thread %d\t received %s' %( self.thread_id, work)
            result_queue.put(out)


def main():
    for i in range(10):
        work_queue.put('message id %d' %i)
    #开启两个工作线程
    for i in range(2):
        thread = WorkThread(i)
        thread.start()
    for i in range(10):
        print(result_queue.get())

if __name__ == '__main__':
    main()
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020年8月21日2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档