淺談Python中threading join和setDaemon用法及區(qū)別說明
Python多線程編程時,經(jīng)常會用到j(luò)oin()和setDaemon()方法,今天特地研究了一下兩者的區(qū)別。
1、join ()方法:主線程A中,創(chuàng)建了子線程B,并且在主線程A中調(diào)用了B.join(),那么,主線程A會在調(diào)用的地方等待,直到子線程B完成操作后,才可以接著往下執(zhí)行,那么在調(diào)用這個線程時可以使用被調(diào)用線程的join方法。
原型:join([timeout])
里面的參數(shù)時可選的,代表線程運(yùn)行的最大時間,即如果超過這個時間,不管這個此線程有沒有執(zhí)行完畢都會被回收,然后主線程或函數(shù)都會接著執(zhí)行的。
例子:
import threading import time class MyThread(threading.Thread): def __init__(self,id): threading.Thread.__init__(self) self.id = id def run(self): x = 0 time.sleep(10) print self.id if __name__ == "__main__": t1=MyThread(999) t1.start() for i in range(5): print I
執(zhí)行后的結(jié)果是:
0
1
2
3
4
999
機(jī)器上運(yùn)行時,4和999之間,有明顯的停頓。
解釋:
線程t1 start后,主線程并沒有等線程t1運(yùn)行結(jié)束后再執(zhí)行,而是先把5次循環(huán)打印執(zhí)行完畢(打印到4),然后sleep(10)后,線程t1把傳進(jìn)去的999才打印出來。
現(xiàn)在,我們把join()方法加進(jìn)去(其他代碼不變),看看有什么不一樣,例子:
import threading import time class MyThread(threading.Thread): def __init__(self,id): threading.Thread.__init__(self) self.id = id def run(self): x = 0 time.sleep(10) print self.id if __name__ == "__main__": t1=MyThread(999) t1.start() t1.join() for i in range(5): print I
執(zhí)行后的結(jié)果是:
999
0
1
2
3
4
機(jī)器上運(yùn)行時,999之前,有明顯的停頓。
解釋:
線程t1 start后,主線程停在了join()方法處,等sleep(10)后,線程t1操作結(jié)束被join,接著,主線程繼續(xù)循環(huán)打印。
2、setDaemon()方法。主線程A中,創(chuàng)建了子線程B,并且在主線程A中調(diào)用了B.setDaemon(),這個的意思是,把主線程A設(shè)置為守護(hù)線程,這時候,要是主線程A執(zhí)行結(jié)束了,就不管子線程B是否完成,一并和主線程A退出.這就是setDaemon方法的含義,這基本和join是相反的。此外,還有個要特別注意的:必須在start() 方法調(diào)用之前設(shè)置,如果不設(shè)置為守護(hù)線程,程序會被無限掛起。
例子:就是設(shè)置子線程隨主線程的結(jié)束而結(jié)束:
import threading import time class MyThread(threading.Thread): def __init__(self,id): threading.Thread.__init__(self) def run(self): time.sleep(5) print "This is " + self.getName() if __name__ == "__main__": t1=MyThread(999) t1.setDaemon(True) t1.start() print "I am the father thread."
執(zhí)行后的結(jié)果是:
I am the father thread.
可以看出,子線程t1中的內(nèi)容并未打出。
解釋:t1.setDaemon(True)的操作,將父線程設(shè)置為了守護(hù)線程。根據(jù)setDaemon()方法的含義,父線程打印內(nèi)容后便結(jié)束了,不管子線程是否執(zhí)行完畢了。
程序運(yùn)行中,執(zhí)行一個主線程,如果主線程又創(chuàng)建一個子線程,主線程和子線程就分兵兩路,分別運(yùn)行,那么當(dāng)主線程完成想退出時,會檢驗(yàn)子線程是否完成。
如果子線程未完成,則主線程會等待子線程完成后再退出。
但是有時候我們需要的是,只要主線程完成了,不管子線程是否完成,都要和主線程一起退出,這時就可以用setDaemon方法了。
所以,join和setDaemon的區(qū)別如上述的例子,它們基本是相反的。
以上這篇淺談Python中threading join和setDaemon用法及區(qū)別說明就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
- Python中threading庫實(shí)現(xiàn)線程鎖與釋放鎖
- Python多線程編程之threading模塊詳解
- Python 多線程之threading 模塊的使用
- python中threading和queue庫實(shí)現(xiàn)多線程編程
- Python threading模塊condition原理及運(yùn)行流程詳解
- Python多線程threading創(chuàng)建及使用方法解析
- Python3 socket即時通訊腳本實(shí)現(xiàn)代碼實(shí)例(threading多線程)
- Python中使用threading.Event協(xié)調(diào)線程的運(yùn)行詳解
- python繼承threading.Thread實(shí)現(xiàn)有返回值的子類實(shí)例
- python中threading開啟關(guān)閉線程操作
- python threading模塊的使用指南
相關(guān)文章
使用Python實(shí)現(xiàn)分組數(shù)據(jù)并保存到單獨(dú)的文件中
當(dāng)處理大型數(shù)據(jù)集時,通常需要將數(shù)據(jù)分組,并將每個分組的數(shù)據(jù)保存到單獨(dú)的文件中,本文將使用 Python 中的 pandas 庫來實(shí)現(xiàn)這一目標(biāo),需要的可以參考下2024-04-04磁盤垃圾文件清理器python代碼實(shí)現(xiàn)
幾行Python代碼打造自己的磁盤垃圾文件清理器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-03-03Django 拆分model和view的實(shí)現(xiàn)方法
今天小編就為大家分享一篇Django 拆分model和view的實(shí)現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-08-08Python3.5多進(jìn)程原理與用法實(shí)例分析
這篇文章主要介紹了Python3.5多進(jìn)程原理與用法,結(jié)合實(shí)例形式分析了多進(jìn)程的原理、單進(jìn)程、多進(jìn)程、進(jìn)程類及進(jìn)程隊列等相關(guān)定義與使用技巧,需要的朋友可以參考下2019-04-04Python3列表內(nèi)置方法大全及示例代碼小結(jié)
這篇文章主要介紹了Python3列表內(nèi)置方法大全及示例代碼小結(jié),非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-05-05