使用Thread和队列Queue实现线程池复用线程

线程池实现

线程池是一个线程管理技术,创建一个或者多个线程进行管理,避免线程的创建和销毁带来的开销线程过多会带来调度开销,进而影响缓存局部性和整体性能。而线程池维护着多个线程,等待着监督管理者分配可并发执行的任务。这避免了在处理短时间任务时创建与销毁线程的代价。线程池不仅能够保证内核的充分利用,还能防止过分调度.
  • 线程池的优点
    • 降低资源消耗;通过重复利用已创建的线程降低创建和销毁造成的消耗。
    • 提高响应速度,不必等待线程的创建,正常情况下(没有任务进入队列的情况)不需要等待。
    • 线程管理,线程统一由线程池管理,随取随用。

自定义线程池实现

from threading import Thread
from queue import Queue
import time
import random
import threading


# 自定义线程池
class MyThreadPool:

    def __init__(self, thread_num):
        self.thread_num = thread_num
        self.task_queue = Queue()

        # 初始化的时候启动线程池
        self.__start()

    # 依次创建并启动线程
    def __start(self):
        for _ in range(self.thread_num):
            Thread(target=self._target, daemon=True).start()

    # 为线程分配任务
    def _target(self):
        while True:
            target, args, kwargs = self.task_queue.get()
            target(*args, **kwargs)
            # 队列计数器减一
            self.task_queue.task_done()

    # 任务队列执行完成之前一直堵塞
    def join(self):
        self.task_queue.join()

    # 往队列中添加任务
    def submit_task(self, target, args=(), kwargs={}):
        self.task_queue.put((target, args, kwargs))


def work(name, no, **kwargs):
    thread_id = threading.get_ident()
    print(f"【子线程{thread_id}-开始】({threading.current_thread()}) ")
    print(f"【子线程{thread_id}-data】 name={name}, no={no}, kwargs={kwargs}")
    time.sleep(random.randint(1, 10))
    print(f"【子线程{thread_id}-结束】")


t_pool = MyThreadPool(3)
for i in range(5):
    t_pool.submit_task(work, (f"任务{i}", i), {"test": 1})

t_pool.join()

【运行效果】:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值