以下のコードは、http: //docs.python.org/2/library/queue.html にある Python の公式キューの例とほぼ同じです。
from Queue import Queue
from threading import Thread
from time import time
import sys
num_worker_threads = int(sys.argv[1])
source = xrange(10000)
def do_work(item):
for i in xrange(100000):
pass
def worker():
while True:
item = q.get()
do_work(item)
q.task_done()
q = Queue()
for item in source:
q.put(item)
start = time()
for i in range(num_worker_threads):
t = Thread(target=worker)
t.daemon = True
t.start()
q.join()
end = time()
print(end - start)
これらは、Xeon 12 コア プロセッサでの結果です。
$ ./speed.py 1
12.0873839855
$ ./speed.py 2
15.9101941586
$ ./speed.py 4
27.5713479519
ワーカーの数を増やすと応答時間が短縮されると予想していましたが、実際には増加しています。何度も実験を繰り返しましたが、結果は変わりませんでした。
明らかな何かが欠けていますか?または、Python キュー/スレッドがうまく機能しませんか?