首页 > 编程语言 > 详细

绝版线程池

时间:2017-01-15 14:50:07      阅读:305      评论:0      收藏:0      [点我收藏+]
import threading,queue,time

StopEvent = object()

class Mythreadpool:

    def __init__(self,max_num):
        self.q = queue.Queue()
        self.max_num = max_num
        self.generate_list = []
        self.free_list = []

    def run(self,func,args,callback=None):
        w = func,args,callback
        self.q.put(w)
        if len(self.free_list) == 0 and len(self.generate_list) < self.max_num:
            self.generate_thread()

    def generate_thread(self):
        t = threading.Thread(target=self.call)
        t.start()

    def call(self):
        current_thread = threading.currentThread
        self.generate_list.append(current_thread)
        event = self.q.get()

        while event != StopEvent:
            func,args,callback = event
            try:
                ret = func(args)
            except Exception as e:
                    ret = e
            try:
                callback(ret)
            except Exception as b:
                pass

            self.free_list.append(current_thread)
            event = self.q.get()
            self.free_list.remove(current_thread)

        else:

            self.generate_list.remove(current_thread)

    def close(self):
        mun = len(self.generate_list)
        while mun:
            self.q.put(StopEvent)
            mun -= 1



def fun(i):
    time.sleep(0.5)
    print(i)

pool = Mythreadpool(15)

for i in range(100):
    pool.run(func=fun,args=i,)

pool.close()

  

绝版线程池

原文:http://www.cnblogs.com/cloniu/p/6287008.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!