亚洲视频二区_亚洲欧洲日本天天堂在线观看_日韩一区二区在线观看_中文字幕不卡一区

公告:魔扣目錄網(wǎng)為廣大站長提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請做好本站友鏈:【 網(wǎng)站目錄:http://www.430618.com 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

多線程概述

多線程使得程序內(nèi)部可以分出多個(gè)線程來做多件事情,充分利用CPU空閑時(shí)間,提升處理效率。Python提供了兩個(gè)模塊來實(shí)現(xiàn)多線程thread 和threading ,thread 有一些缺點(diǎn),在threading 得到了彌補(bǔ)。并且在Python3中廢棄了thread模塊,保留了更強(qiáng)大的threading模塊。

使用場景

在python的原始解釋器CPython中存在著GIL(Global Interpreter Lock,全局解釋器鎖),因此在解釋執(zhí)行python代碼時(shí),會產(chǎn)生互斥鎖來限制線程對共享資源的訪問,直到解釋器遇到I/O操作或者操作次數(shù)達(dá)到一定數(shù)目時(shí)才會釋放GIL。所以,雖然CPython的線程庫直接封裝了系統(tǒng)的原生線程,但CPython整體作為一個(gè)進(jìn)程,同一時(shí)間只會有一個(gè)獲得GIL的線程在跑,其他線程則處于等待狀態(tài)。這就造成了即使在多核CPU中,多線程也只是做著分時(shí)切換而已。

如果你的程序是CPU密集型,多個(gè)線程的代碼很有可能是線性執(zhí)行的。所以這種情況下多線程是雞肋,效率可能還不如單線程因?yàn)橛猩舷挛那袚Q開銷。但是如果你的代碼是IO密集型,涉及到網(wǎng)絡(luò)、磁盤IO的任務(wù)都是IO密集型任務(wù),多線程可以明顯提高效率,例如多線程爬蟲,多線程文件處理等等

多線程爬蟲

多線程爬蟲的代碼實(shí)例

注:以下代碼在python3下運(yùn)行通過, python2版本差異較大,不能運(yùn)行成功,如需幫助請下方留意。

Python3多線程爬蟲實(shí)例講解

 

運(yùn)行結(jié)果:

1個(gè)線程時(shí):

Python3多線程爬蟲實(shí)例講解

 

2個(gè)線程時(shí):

Python3多線程爬蟲實(shí)例講解

 

3個(gè)線程時(shí):

Python3多線程爬蟲實(shí)例講解

 

通過調(diào)節(jié)線程數(shù)可以看到,執(zhí)行時(shí)間會隨著線程數(shù)的增加而縮短,抓取效率成正比增加。

總結(jié):

Python多線程在IO密集型任務(wù),多線程可以明顯提高效率,CPU密集型任務(wù)不適合使用多線程處理。

分享到:
標(biāo)簽:Python3
用戶無頭像

網(wǎng)友整理

注冊時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學(xué)四六

運(yùn)動步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績評定2018-06-03

通用課目體育訓(xùn)練成績評定