线程池的简单实现

池:存任务的空间,存入多个线程就叫线程池。(每个线程开启关闭耗费资源,线程池统一管理,线程可重复使用

重复利用的线程池,代码实现:

# -*- coding: utf-8 -*-
""" 重复利用的线程池 """
from threading import Thread, current_thread
from queue import Queue
import time


class MyThreadPool:
    def __init__(self, n):
        self.queue = Queue()
        # 生成线程池
        for i in range(n):
            Thread(target=self.run, args=(self.queue, ), daemon=True).start()

    def run(self, queue):
        while True:
            task, args, kwargs = self.queue.get()
            task(*args, **kwargs)
            print(current_thread(), task) # 打印当前线程
            self.queue.task_done() # 计数器 -1

    def join(self):
        # queue计数为0时终止程序
        self.queue.join() # 重写thread join方法,调用queue join

    def apply_async(self, func, args=(), kwargs={}):
        self.queue.put((func, args, kwargs)) # 计数器 +1


def apply1(n, m):
    # print('apply1: n+m=', n+m)
    time.sleep(3)

def apply2(n, m):
    # print('apply2: n+m=', n+m)
    time.sleep(3)


if __name__ == '__main__':
    my_thread_pool = MyThreadPool(3)
    my_thread_pool.apply_async(apply1, args=(1, 1))
    my_thread_pool.apply_async(apply2, args=(2, 2))
    my_thread_pool.apply_async(apply1, args=(1, 1))
    my_thread_pool.apply_async(apply2, args=(2, 2))
    my_thread_pool.apply_async(apply1, args=(1, 1))
    my_thread_pool.apply_async(apply2, args=(2, 2))
    # 主线程先执行到这儿,此时queue计数器 +1 *6
    my_thread_pool.join() # 等待计数器为0时结束队列queue阻塞程序

 

posted on 2019-04-01 19:50 .Tang 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/tangpg/p/10638495.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值