python - 使用多线程在不同的运行中获得不同的结果

标签 python multithreading

为什么代码执行时,每次结果都不一样?

我试图跟踪代码是如何执行的,但我很困惑,我觉得这没有意义。

结果每次都是随机出现的

#!/usr/bin/python

import Queue
import threading
import time

exitFlag = 0

class myThread (threading.Thread):
    def __init__(self, threadID, name, q):
        threading.Thread.__init__(self)
        self.threadID = threadID
        self.name = name
        self.q = q
    def run(self):
        print "Starting " + self.name
        process_data(self.name, self.q)
        print "Exiting " + self.name

def process_data(threadName, q):
    while not exitFlag:
        queueLock.acquire()
        if not workQueue.empty():
            data = q.get()
            queueLock.release()
            print "%s processing %s" % (threadName, data)
        else:
            queueLock.release()
        time.sleep(1)

threadList = ["Thread-1", "Thread-2", "Thread-3"]
nameList = ["One", "Two", "Three", "Four", "Five"]
queueLock = threading.Lock()
workQueue = Queue.Queue(10)
threads = []
threadID = 1

# Create new threads
for tName in threadList:
    thread = myThread(threadID, tName, workQueue)
    thread.start()
    threads.append(thread)
    threadID += 1

# Fill the queue
queueLock.acquire()
for word in nameList:
    workQueue.put(word)
queueLock.release()

# Wait for queue to empty
while not workQueue.empty():
    pass

# Notify threads it's time to exit
exitFlag = 1

# Wait for all threads to complete
for t in threads:
    t.join()
print "Exiting Main Thread"

代码来源 http://www.tutorialspoint.com/python/python_multithreading.htm

<小时/>

更新

抱歉,我的意思是结果的顺序

像这样:

Starting Thread-1
Starting Thread-2
Starting Thread-3
Thread-3 processing One
Thread-2 processing Two
Thread-1 processing Three
Thread-3 processing Four
Thread-2 processing Five
Exiting Thread-1
Exiting Thread-3
Exiting Thread-2
Exiting Main Thread
[Finished in 3.0s]

再试一次,结果

Starting Thread-1
Starting Thread-2
Starting Thread-3
Thread-3 processing One
Thread-2 processing Two
Thread-1 processing Three
Thread-3 processing Four
Thread-3 processing Five
Exiting Thread-1
Exiting Thread-2
Exiting Thread-3
Exiting Main Thread
[Finished in 3.0s]

最佳答案

我认为,“结果”指的是执行顺序。 多线程背后的一个想法是,除非您想明确指定,否则您不必关心执行顺序。你完全依赖于底层操作系统、系统负载……等等。

关于python - 使用多线程在不同的运行中获得不同的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19219570/

相关文章:

python - Python中如何统计总分秒数

ios - 中止所有dispatch_semaphore_wait

c - 线程无限期地等待计时器信号

java - 如何停止由线程控制的进程?

python - 如何将抓取的数据保存到 CSV 文件中?

python - 计算 DataFrame 每列值的出现次数

python - 如何使用pygtk打印图像

java - 如何阻止一个线程修改另一个线程正在使用的数组?

java - 如何在线程中使用wait()和notify()进行命令处理

python - 无法在 Python 的多处理中将两个列表组合成一个映射