python线程join
幾個事實
1 python 默認參數(shù)創(chuàng)建線程后,不管主線程是否執(zhí)行完畢,都會等待子線程執(zhí)行完畢才一起退出,有無join結(jié)果一樣
2 如果創(chuàng)建線程,并且設(shè)置了daemon為true,即thread.setDaemon(True), 則主線程執(zhí)行完畢后自動退出,不會等待子線程的執(zhí)行結(jié)果。而且隨著主線程退出,子線程也消亡。
3 join方法的作用是阻塞,等待子線程結(jié)束,join方法有一個參數(shù)是timeout,即如果主線程等待timeout,子線程還沒有結(jié)束,則主線程強制結(jié)束子線程。
4 如果線程daemon屬性為False, 則join里的timeout參數(shù)無效。主線程會一直等待子線程結(jié)束。
5 如果線程daemon屬性為True, 則join里的timeout參數(shù)是有效的, 主線程會等待timeout時間后,結(jié)束子線程。此處有一個坑,即如果同時有N個子線程join(timeout),那么實際上主線程會等待的超時時間最長為 N * timeout, 因為每個子線程的超時開始時刻是上一個子線程超時結(jié)束的時刻。
測試代碼
''' 遇到問題沒人解答?小編創(chuàng)建了一個Python學(xué)習(xí)交流QQ群:857662006 尋找有志同道合的小伙伴,互幫互助, 群里還有不錯的視頻學(xué)習(xí)教程和PDF電子書! ''' import threading,timedef func():print "start thread time: ",time.strftime('%H:%M:%S')time.sleep(3)print "stop thread time: ",time.strftime('%H:%M:%S')thread_list = [] for i in range(3):t1 = threading.Thread(target=func)#t1.setDaemon(True)thread_list.append(t1)for r in thread_list:r.start()for t in thread_list:#t.join(1)t.join() print "stop main thread"###子線程如果設(shè)置了t.join(timeout),則根據(jù)timeout的不同,結(jié)果會不同,前提是設(shè)置了setDaemon(True),否則join的timeout是沒效的#設(shè)置了setDaemon(True),但是沒設(shè)置t.join()的運行結(jié)果: #start thread time: 17:25:29 #start thread time: 17:25:29 #start thread time: 17:25:29 #stop main thread#加了t1.setDaemon(True),并且設(shè)置了超時時間t.join(1)的運行結(jié)果: #start thread time: 17:12:24 #start thread time: 17:12:24 #start thread time: 17:12:24 #stop main thread#沒加t1.setDaemon(True),并且設(shè)置了超時時間t.join(1)的運行結(jié)果,不過因為setDaemon的參數(shù)不是True所以就算設(shè)置了超時時間也沒用: #start thread time: 17:13:28 #start thread time: 17:13:28 #start thread time: 17:13:28 #stop main thread #stop thread time: 17:13:31 #stop thread time: 17:13:31 #stop thread time: 17:13:31#沒加t1.setDaemon(True),但是設(shè)置了t.join(),沒有超時時間的阻塞的運行結(jié)果: #start thread time: 17:16:12 #start thread time: 17:16:12 #start thread time: 17:16:12 #stop thread time: 17:16:15 #stop thread time: 17:16:15 #stop thread time: 17:16:15 #stop main thread #即沒有設(shè)置setDaemon(True),也沒有設(shè)置join()的運行結(jié)果: #start thread time: 17:22:25 #start thread time: 17:22:25 #start thread time: 17:22:25 #stop main thread #stop thread time: 17:22:28 #stop thread time: 17:22:28 #stop thread time: 17:22:28總結(jié):
如果想讓子進程正常的運行結(jié)束(子進程中所有的內(nèi)容都運行了),則如果設(shè)置join(timeout)的話,前提是設(shè)置setDaemon(True),且setDaemon的參數(shù)為True,且join(timeout)的超時時間必須大于子進程執(zhí)行所需的時間,不然沒等子進程運行結(jié)束就超時退出了.或者直接設(shè)置join()不帶超時時間,也不用設(shè)置setDaemon(True)了
總結(jié)
以上是生活随笔為你收集整理的python线程join的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python 并集union, 交集in
- 下一篇: python issubclass 和