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.
我有以下线程打印功能。
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.