我的思路就是就是写一个TifCutting类继承自Thread,这个类里有个属性Queue;有一个addTask添加任务的方法,这个方法是把需要执行的函数放到Queue里;因为继承自Thread类,一定有一个重写的run方法,这个方法是从自己的Queue属性里获取函数,然后执行;有一个StartRun方法,这个方法开了多个线程去执行自身TifCutting类的run方法,即调用多线程里的start方法。直接上代码吧,大家一看就明白了:
#coding=utf-8
from threading import Thread
from Queue import Queue
import time
class TifCutting(Thread):
_running = []
taskQueue = Queue()
def __init__(self):
super(TifCutting, self).__init__()
self.stop = False
@classmethod
def addTask(cls, filePath):
def taskFunc():
print 'start %s' % filePath
time.sleep(1)
print 'end %s' % filePath
cls.taskQueue.put(taskFunc)
@classmethod
def startRun(cls, threadNum=3):
for i in range(threadNum):
t = TifCutting()
t.start()
cls._running.append(t)
@classmethod
def stopRun(cls):
for t in cls._running:
t.stop = True
cls._running = []
def run(self):
while not self.stop:
task = TifCutting.taskQueue.get(timeout=1)
task()
tifCutting = TifCutting()
for i in range(100):
tifCutting.addTask('filePath_%s' % i)
tifCutting.startRun()
我水平太有限,有啥不对的地方欢迎大家指正。。抱拳