Python 线程打印覆盖自身

Python threading print overwriting itself

我有以下线程打印功能。

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 尝试同时打印两者,returns 一个不连贯的语句。有没有办法保证第一输出?

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