在threading中setDaemon和join都是用来设置等待
首先要明确的是:
假设子线程是t
无论是t.setDaemon() 还是 t.join的等待都是相对于主线程来说的。
.join()
t.join()的作用是,当t在执行时,主线程在join处暂停,只有当t结束运行时,才继续执行join下面的语句
如以下程序:
import threading
from time import ctime, sleep
def act1():
for i in range(2):
print("act1 is running at %s" %ctime())
sleep(2)
def act2():
for i in range(2):
print("act2 is running at %s" %ctime())
sleep(4)
threads = []
t1 = threading.Thread(target=act1)
threads.append(t1)
t2 = threading.Thread(target=act2)
threads.append(t2)
if __name__ == '__main__':
for t in threads:
t.start()
print("befor join at %s" %ctime())
t.join()
print("after join")
print("finished at %s" %ctime())
其运行结果是
运行时在befor语句后有停顿,看时间可以发现,主进程是在befor语句执行之后,遇到join语句开始等待t的执行,然后4秒后,t执行完再执行after语句。
.setDaemon
t.setDaemon()中的参数可以是True或False
这里首先要明确一点,t.setDaemon()一定要在t.start()语句之前,否则程序会无限挂起。
参数为False
当为False时,与不设置效果一样,即t执行,主线程也执行,主线程执行完以后,等待t执行完,然后程序结束。
程序修改为:
if __name__ == '__main__':
for t in threads:
print("befor")
t.setDaemon(False)
t.start()
print("after")
print("finished at %s" %ctime())
执行结果为:
程序执行时再finnished at 后停顿
说明主线程和t一同执行,执行完后等待t执行完,结束程序
参数为True
当为True时,是将t设置为守护线程。即,t执行时主线程不暂停继续执行,当主线程执行完了,无论t是否执行完,都一同结束。
程序修改为:
if __name__ == '__main__':
for t in threads:
print("befor")
t.setDaemon(True)
t.start()
print("after")
print("finished at %s" %ctime())
运行结果为:
程序执行期间没有停顿,并且从结果上可以看到,t没有执行完,就随着程序一同结束了。