感谢您提供此主题-它对我也有很大帮助。
我今天学到了有关.join()的知识。
这些线程并行运行:
d.start()
t.start()
d.join()
t.join()
这些依次运行(不是我想要的):
d.start()
d.join()
t.start()
t.join()
特别是,我试图变得聪明和整洁:
class Kiki(threading.Thread):
def __init__(self, time):
super(Kiki, self).__init__()
self.time = time
self.start()
self.join()
这可行!但是它顺序运行。我可以将self.start()放在__ init __中,但是不能将self.join()放入。必须在每个线程启动后执行此操作。
join()是导致主线程等待线程完成的原因。否则,您的线程将独自运行。
因此,有一种方法可以将join()视为主线程上的“保留”对象-它可以对线程进行解线程,并在主线程可以继续之前在主线程中按顺序执行。它可以确保您的线程在主线程向前移动之前是完整的。请注意,这意味着在调用join()之前线程已经完成是可以的-在调用join()时立即立即释放主线程。
实际上,我现在刚想到,主线程在d.join()上等待,直到线程d完成,然后才移至t.join()。
实际上,非常清楚,请考虑以下代码:
import threading
import time
class Kiki(threading.Thread):
def __init__(self, time):
super(Kiki, self).__init__()
self.time = time
self.start()
def run(self):
print self.time, " seconds start!"
for i in range(0,self.time):
time.sleep(1)
print "1 sec of ", self.time
print self.time, " seconds finished!"
t1 = Kiki(3)
t2 = Kiki(2)
t3 = Kiki(1)
t1.join()
print "t1.join() finished"
t2.join()
print "t2.join() finished"
t3.join()
print "t3.join() finished"
它产生此输出(请注意print语句如何彼此穿线。)
$ python test_thread.py
32 seconds start! seconds start!1
seconds start!
1 sec of 1
1 sec of 1 seconds finished!
21 sec of
3
1 sec of 3
1 sec of 2
2 seconds finished!
1 sec of 3
3 seconds finished!
t1.join() finished
t2.join() finished
t3.join() finished
$
t1.join()正在阻止主线程。所有三个线程在t1.join()完成之前完成,并且主线程继续执行打印,然后执行t2.join()然后打印,然后执行t3.join()然后打印。
欢迎更正。我也是线程新手。
(注意:如果您有兴趣,我正在为DrinkBot编写代码,并且我需要线程来同时运行配料泵,而不是顺序运行-等待每个饮料的时间更少。)