非常に単純なマルチスレッドモデルをまとめようとしましたが、これまでのところうまくいくようです。私の質問は、2つのスレッドがキューから同じ値を同時に取得して、繰り返しを与えないようにするにはどうすればよいですか?これを防ぐ組み込みのメソッドはありますか?各スレッドがキューから値を取得するまでの時間を置くために遅延を追加しましたが、これは必要ですか?
from Queue import Queue
from threading import Thread
import time
class myThread(Thread):
def __init__(self,queue):
Thread.__init__(self)
self.queue = queue
def run(self):
while True:
time.sleep(0.0001) #not sure if this is good enough to compensate for overlap in pulling the same value out of a queue
task = self.queue.get() #pull a number from the queue,
if task != None:
out.append(task) #This will be where you
else:
break
queue = Queue()
out = []
for i in range(10):
t = myThread(queue)
t.start()
for i in range(100):
queue.put(i)
print out