我有以下内容打印一个打印功能。
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尝试同时打印两者并返回不连贯的语句。无论如何要确保第一次输出吗?
答案 0 :(得分:2)
是 - 创建queue
。它可以是您附加要打印的新字符串的列表,并使用单独的线程从该列表中删除第一个元素并打印它。确保您的打印线程在while / for循环中运行,并使用sleep(0.1)
方法不使用太多的CPU。