import time
def countdown(n):
while n>0:
with open('thread_log.log','a') as f:
f.write('T-minus'+str(n))
n -=1
time.sleep(5)
from threading import Thread
t= Thread(target=countdown, args=(10,),daemon=True)
t.start()
# t.join()
time.sleep(20)
if t.is_alive():
print('running')
else:
print('completed')
着重讲下daemon这个参数,他是python3中Thread才有的参数。虽然他可以让线程后台继续运行,但是如果主线程结束的话,他是不会执行的。本例中执行结果是在thread_log.log文件中写入T-minus10T-minus9T-minus8T-minus7
说明主线程结束,子线程也就销毁了。