您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“Python線程編程怎么突出語言的新特性”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“Python線程編程怎么突出語言的新特性”吧!
使用 Python 線程編程
通過將線程和隊(duì)列 結(jié)合在一起,可以輕松地在 Python 中完成線程編程。本文將研究同時(shí)使用線程和隊(duì)列,創(chuàng)建一些簡單但有效的模式,以解決需要并發(fā)處理的問題。
引言
對于 Python 來說,并不缺少并發(fā)選項(xiàng),其標(biāo)準(zhǔn)庫中包括了對線程、進(jìn)程和異步 I/O 的支持。在許多情況下,通過創(chuàng)建諸如異步、線程和子進(jìn)程之類的高層模塊,Python 簡化了各種并發(fā)方法的使用。除了標(biāo)準(zhǔn)庫之外,還有一些第三方的解決方案,例如 Twisted、Stackless 和進(jìn)程模塊。
本文重點(diǎn)關(guān)注于使用 Python 的線程,并使用了一些實(shí)際的示例進(jìn)行說明。雖然有許多很好的聯(lián)機(jī)資源詳細(xì)說明了線程 API,但本文嘗試提供一些實(shí)際的示例,以說明一些常見的線程使用模式。
全局解釋器鎖 (Global Interpretor Lock) 說明 Python 解釋器并不是線程安全的。當(dāng)前線程必須持有全局鎖,以便對 Python 對象進(jìn)行安全地訪問。因?yàn)橹挥幸粋€(gè)線程可以獲得 Python 對象/C API,所以解釋器每經(jīng)過 100 個(gè)字節(jié)碼的指令,就有規(guī)律地釋放和重新獲得鎖。解釋器對線程切換進(jìn)行檢查的頻率可以通過 sys.setcheckinterval() 函數(shù)來進(jìn)行控制。
此外,還將根據(jù)潛在的阻塞 I/O 操作,釋放和重新獲得鎖。有關(guān)更詳細(xì)的信息,請參見參考資料部分中的 Gil and Threading State 和 Threading the Global Interpreter Lock需要說明的是,因?yàn)?GIL,CPU 受限的應(yīng)用程序?qū)o法從線程的使用中受益。使用 Python 時(shí),建議使用進(jìn)程,或者混合創(chuàng)建進(jìn)程和線程。
首先弄清進(jìn)程和線程之間的區(qū)別,這一點(diǎn)是非常重要的。線程與進(jìn)程的不同之處在于,它們共享狀態(tài)、內(nèi)存和資源。對于線程來說,這個(gè)簡單的區(qū)別既是它的優(yōu)勢,又是它的缺點(diǎn)。一方面,線程是輕量級的,并且相互之間易于通信,但另一方面,它們也帶來了包括死鎖、爭用條件和高復(fù)雜性在內(nèi)的各種問題。幸運(yùn)的是,由于 GIL 和隊(duì)列模塊,與采用其他的語言相比,采用 Python 語言在線程實(shí)現(xiàn)的復(fù)雜性上要低得多。
使用 Python 線程
要繼續(xù)學(xué)習(xí)本文中的內(nèi)容,我假定您已經(jīng)安裝了 Python 2.5 或者更高版本,因?yàn)楸疚闹械脑S多示例都將使用 Python 語言的新特性,而這些特性僅出現(xiàn)于 Python2.5 之后。要開始使用 Python 語言的線程,我們將從簡單的 "Hello World" 示例開始:
hello_threads_example import threading import datetime class ThreadClass(threading.Thread): def run(self): now = datetime.datetime.now() print "%s says Hello World at time: %s" % (self.getName(), now) for i in range(2): t = ThreadClass() t.start()
如果運(yùn)行這個(gè)示例,您將得到下面的輸出:
# python hello_threads.py Thread-1 says Hello World at time: 2008-05-13 13:22:50.252069 Thread-2 says Hello World at time: 2008-05-13 13:22:50.252576
到此,相信大家對“Python線程編程怎么突出語言的新特性”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。