这个问题在这里已有答案:
我有以下哪些线程打印功能。
from threading import Thread
from random import *
import time
def PrintRandom():
rand = random()
time.sleep(rand)
print(rand)
if __name__ == "__main__":
Thread(target=PrintRandom).start()
Thread(target=PrintRandom).start()
这在大多数情况下都有效,输出如下
0.30041615558463897
0.5644155082254415
然而,一旦在蓝色的月亮中,输出以下内容
0.56441550822544150.5644155082254416
shell尝试同时打印两者并返回不连贯的语句。反正有没有确保第一次输出?
是的 - 创建queue
。它可以是您附加要打印的新字符串的列表,并使用单独的线程从该列表中删除第一个元素并打印它。确保您的打印线程在while / for循环中运行,并使用sleep(0.1)
方法不使用太多CPU。