тестовый код очень прост:
import threading, Queue
import time, random
class Worker(threading.Thread):
def __init__(self, index, queue):
threading.Thread.__init__(self)
self.index = index
self.queue = queue
def run(self):
while 1:
time.sleep(random.random())
item = self.queue.get()
if item is None:
break
print "index:", self.index, "task", item, "finished"
self.queue.task_done()
queue = Queue.Queue(0)
for i in range(2):
Worker(i, queue).start()
for i in range(10):
queue.put(i)
for i in range(2):
queue.put(None)
print "Main OK"
и результат немного меняется каждый раз, когда я запускаю его, вот только один:
Main OK
index: 1 task 0 finished
index: 0 task 1 finished
index: 0 task 2 finished
index: 1 task 3 finished
index: 1 task 4 finished
index: 0 task 5 finished
index: 1 task 6 finished
index: 0 task 7 finished
index: 1 task 8 finished
index: 1 task 9 finished
IMO, когда основной поток завершается, будет напечатано «Main OK», затем будет выполняться первый поток, пока он не войдет в time.sleep(random.random())
, затем первый поток перейдет в спящий режим, а второй поток продолжится. То же самое относится к первому потоку, второй поток будет находиться в спящем режиме при входе в time.sleep(random.random())
, затем первый поток продолжится снова. и он напечатает index:0 task 0 finished
сразу после Main OK
, но в действительности то, что следует за Main OK
, равно index: 1...
, а не index: 0...
! Зачем? и кажется, что очередь не работает как обычный многопоточный, иногда один и тот же индексный поток будет выполняться три раза или более непрерывно! В каком мире работает механизм очереди? любая помощь приветствуется!