-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathworker.py
More file actions
35 lines (29 loc) · 893 Bytes
/
worker.py
File metadata and controls
35 lines (29 loc) · 893 Bytes
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
32
33
34
35
import queue
import threading
from threading import Thread
class Worker:
def __init__(self,task, number_worker,max_size_queue=0):
self.task = task
self.number_worker = number_worker
self.max_size_queue = max_size_queue
self.q = queue.Queue(maxsize=0)
self.threads = []
for i in range(self.number_worker):
t = threading.Thread(target=self.__worker__)
t.start()
self.threads.append(t)
def __worker__(self):
while True:
item = self.q.get()
if item is None:
break
self.task(item)
self.q.task_done()
def add_job(self,item):
self.q.put(item)
def wait_and_stop(self):
self.q.join()
for i in range(self.number_worker):
self.q.put(None)
for t in self.threads:
t.join()