-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy paththread.py
31 lines (30 loc) · 1.14 KB
/
thread.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
import threading, progressbar, random
class ThreadPool:
def __init__(self, threadCount):
self.__lock = lock = threading.Lock()
self.__threadCount = threadCount
def work(self, tasks, show):
count = 0
for task in tasks:
self.__work(*task)
count = count + 1
if show[count] == 0:
with self.__lock:
self.__total = self.__total + count
self.__bar.update(self.__total + 1)
def Start(self, work, tasks):
length = len(tasks)
self.__bar = progressbar.ProgressBar(maxval=length)
show = [random.randint(0, 100) for i in range(length)]
self.__threads = []
self.__total = 0
self.__work = work
for threadId in range(self.__threadCount):
data = [tasks[i] for i in range(length) if i % self.__threadCount == threadId]
thread = threading.Thread(target=self.work, args=(data, show, ))
self.__threads.append(thread)
thread.start()
def Join(self):
for thread in self.__threads:
thread.join()
self.__bar.finish()