日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

Python GIL、CPU密集型、IO密集型

系統(tǒng) 2425 0

Python GIL(Global Interpreter Lock(全局解釋器鎖))

Python GIL、CPU密集型、IO密集型_第1張圖片

1:進程里面多個線程,線程 共享A=10

2:Python解釋器,A改完值之后會傳回進程容器,為了防止A和B同時修改A的值引起的錯誤,加入鎖,能保證A修改時,B和C不能修改

3:通過C語言調(diào)用底層命令與操作系統(tǒng)進行交互,然后OS再和硬件進行交互

什么是CPU密集型、IO密集型

IO密集型(I/O bound): 指的是系統(tǒng)的CPU性能相對硬盤、內(nèi)存要好很多,此時,系統(tǒng)運作,大部分狀況是CPU在等IO(硬盤/內(nèi)存)的讀/寫操作,此時CPU loading并不高, 即便是程序性能達到極限時,CPU占用率仍然很低,可能的原因是任務本身需要大量的IO操作,而pipeline做的并不是很好,沒有充分利用處理器的能力

CPU密集型(CPU bound):也叫計算密集型,指的是系統(tǒng)的硬盤、內(nèi)存性能相對CPU要好很多(比如我的破電腦,CPU是i5三代的,但是內(nèi)存8G,256G固態(tài),打開大一點的項目CPU就占用100%了,但是內(nèi)存才占用一半左右),IO很短時間內(nèi)完成,但是CPU還有許多運算要處理; CPU bound 的程序一般而言CPU占用率相當高,可能是因為任務本身不太需要訪問IO設備,也可能是因為程序是多線程實現(xiàn)因此屏蔽掉了等待IO的時間

計算密集型任務由于主要消耗CPU資源,因此,代碼運行效率至關(guān)重要。Python這樣的腳本語言運行效率很低,完全不適合計算密集型任務。對于計算密集型任務,最好用C語言編寫。

IO密集型任務執(zhí)行期間,99%的時間都花在IO上,花在CPU上的時間很少,因此,用運行速度極快的C語言替換用Python這樣運行速度極低的腳本語言,完全無法提升運行效率。對于IO密集型任務,最合適的語言就是開發(fā)效率最高(代碼量最少)的語言,腳本語言是首選,C語言最差。

總之,計算密集型程序適合C語言多線程,I/O密集型適合腳本語言開發(fā)的多線程。

freeze_support()有什么作用


更多文章、技術(shù)交流、商務合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 夹江县| 格尔木市| 荃湾区| 宁海县| 荥经县| 香河县| 潼南县| 寿光市| 滨州市| 民和| 毕节市| 昌平区| 张掖市| 潜山县| 南汇区| 乌拉特中旗| 沙雅县| 阜城县| 弥勒县| 四平市| 湘潭县| 孝昌县| 花莲县| 虞城县| 鄯善县| 平阴县| 交城县| 金门县| 南岸区| 视频| 和硕县| 宿松县| 铜陵市| 台南市| 合肥市| 平顺县| 马边| 虹口区| 屯留县| 阿勒泰市| 肥城市|