線程池[2021-03-18]

線程池的使用

線程池的基類是 concurrent.futures 模塊中的 Executor,Executor 提供了兩個(gè)子類约郁,即 ThreadPoolExecutor 和 ProcessPoolExecutor战惊,其中 ThreadPoolExecutor 用于創(chuàng)建線程池,而 ProcessPoolExecutor 用于創(chuàng)建進(jìn)程池。

如果使用線程池/進(jìn)程池來(lái)管理并發(fā)編程吞获,那么只要將相應(yīng)的 task 函數(shù)提交給線程池/進(jìn)程池况凉,剩下的事情就由線程池/進(jìn)程池來(lái)搞定。

Exectuor 提供了如下常用方法:

  • submit(fn, *args, kwargs):將 fn 函數(shù)提交給線程池各拷。args 代表傳給 fn 函數(shù)的參數(shù)刁绒,kwargs 代表以關(guān)鍵字參數(shù)的形式為 fn 函數(shù)傳入?yún)?shù)。
  • map(func, *iterables, timeout=None, chunksize=1):該函數(shù)類似于全局函數(shù) map(func, *iterables)烤黍,只是該函數(shù)將會(huì)啟動(dòng)多個(gè)線程知市,以異步方式立即對(duì) iterables 執(zhí)行 map 處理。
  • shutdown(wait=True):關(guān)閉線程池速蕊。

程序?qū)?task 函數(shù)提交(submit)給線程池后嫂丙,submit 方法會(huì)返回一個(gè) Future 對(duì)象,F(xiàn)uture 類主要用于獲取線程任務(wù)函數(shù)的返回值规哲。由于線程任務(wù)會(huì)在新線程中以異步方式執(zhí)行跟啤,因此,線程執(zhí)行的函數(shù)相當(dāng)于一個(gè)“將來(lái)完成”的任務(wù)唉锌,所以 Python 使用 Future 來(lái)代表隅肥。

實(shí)際上,在 Java 的多線程編程中同樣有 Future袄简,此處的 Future 與 Java 的 Future 大同小異腥放。

Future 提供了如下方法:

  • cancel():取消該 Future 代表的線程任務(wù)。如果該任務(wù)正在執(zhí)行绿语,不可取消秃症,則該方法返回 False;否則汞舱,程序會(huì)取消該任務(wù)伍纫,并返回 True。
  • cancelled():返回 Future 代表的線程任務(wù)是否被成功取消昂芜。
  • running():如果該 Future 代表的線程任務(wù)正在執(zhí)行莹规、不可被取消,該方法返回 True泌神。
  • done():如果該 Funture 代表的線程任務(wù)被成功取消或執(zhí)行完成良漱,則該方法返回 True。
  • result(timeout=None):獲取該 Future 代表的線程任務(wù)最后返回的結(jié)果欢际。如果 Future 代表的線程任務(wù)還未完成母市,該方法將會(huì)阻塞當(dāng)前線程,其中 timeout 參數(shù)指定最多阻塞多少秒损趋。
  • exception(timeout=None):獲取該 Future 代表的線程任務(wù)所引發(fā)的異常患久。如果該任務(wù)成功完成,沒有異常,則該方法返回 None蒋失。
  • add_done_callback(fn):為該 Future 代表的線程任務(wù)注冊(cè)一個(gè)“回調(diào)函數(shù)”返帕,當(dāng)該任務(wù)成功完成時(shí),程序會(huì)自動(dòng)觸發(fā)該 fn 函數(shù)篙挽。

在用完一個(gè)線程池后荆萤,應(yīng)該調(diào)用該線程池的 shutdown() 方法,該方法將啟動(dòng)線程池的關(guān)閉序列铣卡。調(diào)用 shutdown() 方法后的線程池不再接收新任務(wù)链韭,但會(huì)將以前所有的已提交任務(wù)執(zhí)行完成。當(dāng)線程池中的所有任務(wù)都執(zhí)行完成后煮落,該線程池中的所有線程都會(huì)死亡敞峭。

使用線程池來(lái)執(zhí)行線程任務(wù)的步驟如下:

  1. 調(diào)用 ThreadPoolExecutor 類的構(gòu)造器創(chuàng)建一個(gè)線程池。
  2. 定義一個(gè)普通函數(shù)作為線程任務(wù)州邢。
  3. 調(diào)用 ThreadPoolExecutor 對(duì)象的 submit() 方法來(lái)提交線程任務(wù)儡陨。
  4. 當(dāng)不想提交任何任務(wù)時(shí),調(diào)用 ThreadPoolExecutor 對(duì)象的 shutdown() 方法來(lái)關(guān)閉線程池量淌。
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末骗村,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子呀枢,更是在濱河造成了極大的恐慌胚股,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,252評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件裙秋,死亡現(xiàn)場(chǎng)離奇詭異琅拌,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)摘刑,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門进宝,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人枷恕,你說(shuō)我怎么就攤上這事党晋。” “怎么了徐块?”我有些...
    開封第一講書人閱讀 168,814評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵未玻,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我胡控,道長(zhǎng)扳剿,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,869評(píng)論 1 299
  • 正文 為了忘掉前任昼激,我火速辦了婚禮庇绽,結(jié)果婚禮上锡搜,老公的妹妹穿的比我還像新娘。我一直安慰自己瞧掺,他們只是感情好余爆,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,888評(píng)論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著夸盟,像睡著了一般。 火紅的嫁衣襯著肌膚如雪像捶。 梳的紋絲不亂的頭發(fā)上上陕,一...
    開封第一講書人閱讀 52,475評(píng)論 1 312
  • 那天,我揣著相機(jī)與錄音拓春,去河邊找鬼释簿。 笑死,一個(gè)胖子當(dāng)著我的面吹牛硼莽,可吹牛的內(nèi)容都是我干的庶溶。 我是一名探鬼主播,決...
    沈念sama閱讀 41,010評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼懂鸵,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼偏螺!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起匆光,我...
    開封第一講書人閱讀 39,924評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤套像,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后终息,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體夺巩,經(jīng)...
    沈念sama閱讀 46,469評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,552評(píng)論 3 342
  • 正文 我和宋清朗相戀三年周崭,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了柳譬。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,680評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡续镇,死狀恐怖美澳,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情磨取,我是刑警寧澤人柿,帶...
    沈念sama閱讀 36,362評(píng)論 5 351
  • 正文 年R本政府宣布,位于F島的核電站忙厌,受9級(jí)特大地震影響凫岖,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜逢净,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,037評(píng)論 3 335
  • 文/蒙蒙 一哥放、第九天 我趴在偏房一處隱蔽的房頂上張望歼指。 院中可真熱鬧,春花似錦甥雕、人聲如沸踩身。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,519評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)挟阻。三九已至,卻和暖如春峭弟,著一層夾襖步出監(jiān)牢的瞬間附鸽,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,621評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工瞒瘸, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留坷备,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,099評(píng)論 3 378
  • 正文 我出身青樓情臭,卻偏偏與公主長(zhǎng)得像省撑,于是被迫代替她去往敵國(guó)和親昧互。 傳聞我的和親對(duì)象是個(gè)殘疾皇子粥鞋,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,691評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容