Python這門(mén)解釋性語(yǔ)言也有專(zhuān)門(mén)的線程模型,Python虛擬機(jī)使用GIL(Global Interpreter Lock,全局解釋器鎖)來(lái)互斥線程對(duì)共享資源的訪問(wèn),但暫時(shí)無(wú)法利用多處理器的優(yōu)勢(shì)。在Python中我們主要是通過(guò)thread和 threading這兩個(gè)模塊來(lái)實(shí)現(xiàn)的,其中Python的threading模塊是對(duì)thread做了一些包裝的,可以更加方便的被使用,所以我們使用 threading模塊實(shí)現(xiàn)多線程編程。這篇文章我們主要來(lái)看看Python對(duì)多線程編程的支持。
在語(yǔ)言層面,Python對(duì)多線程提供了很好的支持,可以方便地支持創(chuàng)建線程、互斥鎖、信號(hào)量、同步等特性。下面就是官網(wǎng)上介紹threading模塊的基本資料及功能:
實(shí)現(xiàn)模塊
thread:多線程的底層支持模塊,一般不建議使用;
threading:對(duì)thread進(jìn)行了封裝,將一些線程的操作對(duì)象化。
threading模塊
Thread 線程類(lèi),這是我們用的最多的一個(gè)類(lèi),你可以指定線程函數(shù)執(zhí)行或者繼承自它都可以實(shí)現(xiàn)子線程功能;
Timer與Thread類(lèi)似,但要等待一段時(shí)間后才開(kāi)始運(yùn)行;
Lock 鎖原語(yǔ),這個(gè)我們可以對(duì)全局變量互斥時(shí)使用;
RLock 可重入鎖,使單線程可以再次獲得已經(jīng)獲得的鎖;
Condition 條件變量,能讓一個(gè)線程停下來(lái),等待其他線程滿(mǎn)足某個(gè)“條件”;
Event 通用的條件變量。多個(gè)線程可以等待某個(gè)事件發(fā)生,在事件發(fā)生后,所有的線程都被激活;
Semaphore為等待鎖的線程提供一個(gè)類(lèi)似“等候室”的結(jié)構(gòu);
BoundedSemaphore 與semaphore類(lèi)似,但不允許超過(guò)初始值;
Queue:實(shí)現(xiàn)了多生產(chǎn)者(Producer)、多消費(fèi)者(Consumer)的隊(duì)列,支持鎖原語(yǔ),能夠在多個(gè)線程之間提供很好的同步支持。
Thread類(lèi)
是你主要的線程類(lèi),可以創(chuàng)建進(jìn)程實(shí)例。該類(lèi)提供的函數(shù)包括:
getName(self) 返回線程的名字
isAlive(self) 布爾標(biāo)志,表示這個(gè)線程是否還在運(yùn)行中
isDaemon(self) 返回線程的daemon標(biāo)志
join(self, timeout=None) 程序掛起,直到線程結(jié)束,如果給出timeout,則最多阻塞timeout秒
run(self) 定義線程的功能函數(shù)
setDaemon(self, daemonic) 把線程的daemon標(biāo)志設(shè)為daemonic
setName(self, name) 設(shè)置線程的名字
start(self) 開(kāi)始線程執(zhí)行
Queue提供的類(lèi)
Queue隊(duì)列
LifoQueue后入先出(LIFO)隊(duì)列
PriorityQueue 優(yōu)先隊(duì)列
接下來(lái)
接下來(lái)的一系列文章,將會(huì)用一個(gè)一個(gè)示例來(lái)展示threading的各個(gè)功能,包括但不限于:兩種方式起線程、threading.Thread類(lèi)的重要函數(shù)、使用Lock互斥及RLock實(shí)現(xiàn)重入鎖、使用Condition實(shí)現(xiàn)生產(chǎn)者和消費(fèi)者模型、使用Event和Semaphore多線程通信。
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
