Python线程打印覆盖本身

时间:2018-03-06 12:11:20

标签: python multithreading python-multithreading

我有以下内容打印一个打印功能。

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尝试同时打印两者并返回不连贯的语句。无论如何要确保第一次输出吗?

1 个答案:

答案 0 :(得分:2)

是 - 创建queue。它可以是您附加要打印的新字符串的列表,并使用单独的线程从该列表中删除第一个元素并打印它。确保您的打印线程在while / for循环中运行,并使用sleep(0.1)方法不使用太多的CPU。