在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

python多線程和多進(jìn)程的對比

python爬蟲知識分享 ? 來源:python爬蟲知識分享 ? 作者:python爬蟲知識分享 ? 2022-03-15 16:42 ? 次閱讀

1. 基本概念

在開始講解理論知識之前,先過一下幾個基本概念。雖然咱是進(jìn)階教程,但我也希望寫得更小白,更通俗易懂。

串行:一個人在同一時間段只能干一件事,譬如吃完飯才能看電視;

并行:一個人在同一時間段可以干多件事,譬如可以邊吃飯邊看電視;

Python中,多線程協(xié)程 雖然是嚴(yán)格上來說是串行,但卻比一般的串行程序執(zhí)行效率高得很。 一般的串行程序,在程序阻塞的時候,只能干等著,不能去做其他事。就好像,電視上播完正劇,進(jìn)入廣告時間,我們卻不能去趁廣告時間是吃個飯。對于程序來說,這樣做顯然是效率極低的,是不合理的。

雖然 多線程協(xié)程 已經(jīng)相當(dāng)智能了。但還是不夠高效,最高效的應(yīng)該是一心多用,邊看電視邊吃飯邊聊天。這就是我們的 多進(jìn)程 才能做的事了。

2. 單線程VS多線程VS多進(jìn)程

文字總是蒼白無力的,不如用代碼直接來測試一下。

開始對比之前,首先定義四種類型的場景

- CPU計算密集型

- 磁盤IO密集型

- 網(wǎng)絡(luò)IO密集型

- 【模擬】IO密集型

為什么是這幾種場景,這和多線程 多進(jìn)程的適用場景有關(guān)。結(jié)論里,我再說明。

# CPU計算密集型
def count(x=1, y=1):
    # 使程序完成150萬計算
    c = 0
    while c < 500000:
        c += 1
        x += x
        y += y


# 磁盤讀寫IO密集型
def io_disk():
    with open("file.txt", "w") as f:
        for x in range(5000000):
            f.write("python-learning\n")


# 網(wǎng)絡(luò)IO密集型
header = {
    'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/66.0.3359.139 Safari/537.36'}
url = "https://www.tieba.com/"

def io_request():
    try:
        webPage = requests.get(url, headers=header)
        html = webPage.text
        return
    except Exception as e:
        return {"error": e}


# 【模擬】IO密集型
def io_simulation():
    time.sleep(2)

比拼的指標(biāo),我們用時間來考量。時間耗費得越少,說明效率越高。

為了方便,使得代碼看起來,更加簡潔,我這里先定義是一個簡單的 時間計時器 的裝飾器。 如果你對裝飾器還不是很了解,也沒關(guān)系,你只要知道它是用于 計算函數(shù)運行時間的東西就可以了。

def timer(mode):
    def wrapper(func):
        def deco(*args, **kw):
            type = kw.setdefault('type', None)
            t1=time.time()
            func(*args, **kw)
            t2=time.time()
            cost_time = t2-t1
            print("{}-{}花費時間:{}秒".format(mode, type,cost_time))
        return deco
    return wrapper

第一步,先來看看單線程的
@timer("【單線程】")
def single_thread(func, type=""):
    for i in range(10):
              func()

# 單線程
single_thread(count, type="CPU計算密集型")
single_thread(io_disk, type="磁盤IO密集型")
single_thread(io_request,type="網(wǎng)絡(luò)IO密集型")
single_thread(io_simulation,type="模擬IO密集型")

看看結(jié)果

【單線程】-CPU計算密集型花費時間:83.42633867263794秒
【單線程】-磁盤IO密集型花費時間:15.641993284225464秒
【單線程】-網(wǎng)絡(luò)IO密集型花費時間:1.1397218704223633秒
【單線程】-模擬IO密集型花費時間:20.020972728729248秒

第二步,再來看看多線程的

@timer("【多線程】")
def multi_thread(func, type=""):
    thread_list = []
    for i in range(10):
        t=Thread(target=func, args=())
        thread_list.append(t)
        t.start()
    e = len(thread_list)

    while True:
        for th in thread_list:
            if not th.is_alive():
                e -= 1
        if e <= 0:
            break

# 多線程
multi_thread(count, type="CPU計算密集型")
multi_thread(io_disk, type="磁盤IO密集型")
multi_thread(io_request, type="網(wǎng)絡(luò)IO密集型")
multi_thread(io_simulation, type="模擬IO密集型")

看看結(jié)果

【多線程】-CPU計算密集型花費時間:93.82986998558044秒
【多線程】-磁盤IO密集型花費時間:13.270896911621094秒
【多線程】-網(wǎng)絡(luò)IO密集型花費時間:0.1828296184539795秒
【多線程】-模擬IO密集型花費時間:2.0288875102996826秒

第三步,最后來看看多進(jìn)程

@timer("【多進(jìn)程】")
def multi_process(func, type=""):
    process_list = []
    for x in range(10):
        p = Process(target=func, args=())
        process_list.append(p)
        p.start()
    e = process_list.__len__()

    while True:
        for pr in process_list:
            if not pr.is_alive():
                e -= 1
        if e <= 0:
            break

# 多進(jìn)程
multi_process(count, type="CPU計算密集型")
multi_process(io_disk, type="磁盤IO密集型")
multi_process(io_request, type="網(wǎng)絡(luò)IO密集型")
multi_process(io_simulation, type="模擬IO密集型")

看看結(jié)果

【多進(jìn)程】-CPU計算密集型花費時間:9.082211017608643秒
【多進(jìn)程】-磁盤IO密集型花費時間:1.287339448928833秒
【多進(jìn)程】-網(wǎng)絡(luò)IO密集型花費時間:0.13074755668640137秒
【多進(jìn)程】-模擬IO密集型花費時間:2.0076842308044434秒

3. 性能對比成果總結(jié)

將結(jié)果匯總一下,制成表格。

https://file.elecfans.com//web2/M00/36/11/poYBAGIwUWCALmJbAADPTR8eNVs753.png

我們來分析下這個表格。

首先是CPU密集型,多線程以對比單線程,不僅沒有優(yōu)勢,顯然還由于要不斷的加鎖釋放GIL全局鎖,切換線程而耗費大量時間,效率低下,而多進(jìn)程,由于是多個CPU同時進(jìn)行計算工作,相當(dāng)于十個人做一個人的作業(yè),顯然效率是成倍增長的。

然后是IO密集型,IO密集型可以是磁盤IO網(wǎng)絡(luò)IO,數(shù)據(jù)庫IO等,都屬于同一類,計算量很小,主要是IO等待時間的浪費。通過觀察,可以發(fā)現(xiàn),我們磁盤IO,網(wǎng)絡(luò)IO的數(shù)據(jù),多線程對比單線程也沒體現(xiàn)出很大的優(yōu)勢來。這是由于我們程序的的IO任務(wù)不夠繁重,所以優(yōu)勢不夠明顯。

所以我還加了一個「模擬IO密集型」,用sleep來模擬IO等待時間,就是為了體現(xiàn)出多線程的優(yōu)勢,也能讓大家更加直觀的理解多線程的工作過程。單線程需要每個線程都要sleep(2),10個線程就是20s,而多線程,在sleep(2)的時候,會切換到其他線程,使得10個線程同時sleep(2),最終10個線程也就只有2s.

可以得出以下幾點結(jié)論

單線程總是最慢的,多進(jìn)程總是最快的。

多線程適合在IO密集場景下使用,譬如爬蟲,網(wǎng)站開發(fā)等

多進(jìn)程適合在對CPU計算運算要求較高的場景下使用,譬如大數(shù)據(jù)分析,機(jī)器學(xué)習(xí)

多進(jìn)程雖然總是最快的,但是不一定是最優(yōu)的選擇,因為它需要CPU資源支持下才能體現(xiàn)優(yōu)勢

審核編輯:符乾江

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 多線程
    +關(guān)注

    關(guān)注

    0

    文章

    279

    瀏覽量

    20344
  • python
    +關(guān)注

    關(guān)注

    56

    文章

    4825

    瀏覽量

    86370
收藏 人收藏

    評論

    相關(guān)推薦
    熱點推薦

    多線程的安全注意事項

    多線程安全是指多個線程同時訪問或修改共享資源時,能夠保證程序的正確性和可靠性。 開發(fā)者選擇TaskPool或Worker進(jìn)行多線程開發(fā)時,在TaskPool和Worker的工作線程中導(dǎo)
    發(fā)表于 06-20 07:49

    TaskPool和Worker的對比分析

    支持。不支持。適用場景對比 TaskPool和Worker均支持多線程并發(fā)能力。由于TaskPool的工作線程會綁定系統(tǒng)的調(diào)度優(yōu)先級,并且支持負(fù)載均衡(自動擴(kuò)縮容),而Worker需要開發(fā)者自行創(chuàng)建
    發(fā)表于 06-18 06:43

    進(jìn)程、線程、協(xié)程傻傻分不清?一文帶你徹底扒光它們的\"底褲\"!

    外賣員(線程C):負(fù)責(zé)送外賣他們共用: 原料冰箱(共享內(nèi)存) 工作臺(??臻g)但不共享: 自己的工牌(線程ID) 心情日記(線程本地存儲) 代碼示例(Python
    發(fā)表于 03-26 09:27

    請問如何在Python中實現(xiàn)多線程多進(jìn)程的協(xié)作?

    大家好!我最近在開發(fā)一個Python項目時,需要同時處理多個任務(wù),且每個任務(wù)需要不同的計算資源。我想通過多線程多進(jìn)程的組合來實現(xiàn)并發(fā),但遇到了一些問題。 具體來說,我有兩個任務(wù),一個是I/O密集型
    發(fā)表于 03-11 06:57

    請問rt-thread studio如何進(jìn)行多線程編譯?

    ,使用的是5800h+32g內(nèi)存+sn550 ssd,開啟16線程編譯時cpu的占用率也只能到30%,編譯完整個工程需要3分鐘 感覺多線程編譯設(shè)置沒有生效,有辦法提高編譯速度嗎
    發(fā)表于 02-19 08:30

    迅為3A6000開發(fā)板/龍芯3A6000與龍芯3A5000等龍架構(gòu)處理器軟件兼容

    /140 分;SPEC CPU 2017 base 單線程(rate1)定/浮點分值分別達(dá)到 5.05/7.78 分,單進(jìn)程多線程(speed)定/浮點分值分別達(dá)到 6.66/18.1 分,
    發(fā)表于 02-12 15:06

    迅為3A6000_7A2000開發(fā)板龍芯全國產(chǎn)處理器與龍芯 3A5000完全兼容

    /140 分;SPEC CPU 2017 base 單線程(rate1)定/浮點分值分別達(dá)到 5.05/7.78 分,單進(jìn)程多線程(speed)定/浮點分值分別達(dá)到 6.66/18.1 分,
    發(fā)表于 11-19 11:15

    對比Python與Java編程語言

    Python與Java都是目前非常流行的編程語言,它們各有其獨特的優(yōu)勢和適用場景。以下是對這兩種編程語言的對比: 一、語法和易用性 Python 語法簡潔,代碼更易讀,非常適合初學(xué)者。 動態(tài)類型系統(tǒng)
    的頭像 發(fā)表于 11-15 09:31 ?958次閱讀

    socket 多線程編程實現(xiàn)方法

    是指在同一個進(jìn)程中運行多個線程,每個線程可以獨立執(zhí)行任務(wù)。線程共享進(jìn)程的資源,如內(nèi)存空間和文件句柄,但每個
    的頭像 發(fā)表于 11-12 14:16 ?940次閱讀

    一文搞懂Linux進(jìn)程的睡眠和喚醒

    機(jī)制 1)信號(Signal): 進(jìn)程可以通過接受特定信號被喚醒。 2)條件變量(Condition Variable): 多線程編程中用于同步多個線程的工具,可以讓一個線程在某些
    發(fā)表于 11-04 15:15

    Python多線程多進(jìn)程的區(qū)別

    Python作為一種高級編程語言,提供了多種并發(fā)編程的方式,其中多線程多進(jìn)程是最常見的兩種方式之一。在本文中,我們將探討Python多線程
    的頭像 發(fā)表于 10-23 11:48 ?955次閱讀
    <b class='flag-5'>Python</b>中<b class='flag-5'>多線程</b>和<b class='flag-5'>多進(jìn)程</b>的區(qū)別

    迅為3A6000_7A2000核心主板龍芯全國產(chǎn)處理器LoongArch架構(gòu)

    /140 分;SPEC CPU 2017 base 單線程(rate1)定/浮點分值分別達(dá)到 5.05/7.78 分,單進(jìn)程多線程(speed)定/浮點分值分別達(dá)到 6.66/18.1 分,
    發(fā)表于 10-12 11:25

    一文掌握Python多線程

    使用線程可以把占據(jù)長時間的程序中的任務(wù)放到后臺去處理。
    的頭像 發(fā)表于 08-05 15:46 ?1209次閱讀

    ESP32會不會有多線程問題,需要加鎖嗎?

    ESP32會不會有多線程問題,需要加鎖嗎
    發(fā)表于 07-19 08:05

    多線程設(shè)計模式到對 CompletableFuture 的應(yīng)用

    最近在開發(fā) 延保服務(wù) 頻道頁時,為了提高查詢效率,使用到了多線程技術(shù)。為了對多線程方案設(shè)計有更加充分的了解,在業(yè)余時間讀完了《圖解 Java 多線程設(shè)計模式》這本書,覺得收獲良多。本篇文章將介紹其中
    的頭像 發(fā)表于 06-26 14:18 ?646次閱讀
    從<b class='flag-5'>多線程</b>設(shè)計模式到對 CompletableFuture 的應(yīng)用
    主站蜘蛛池模板: 97一本大道波多野吉衣 | 最近2018免费中文字幕视频 | 久久美女精品 | 亚洲国产精品第一页 | 教官的好爽好深h片段 | 夜夜操伊人 | 色优优| 日本a级片在线播放 | 免费啪啪网站 | 日韩有码电影 | 亚洲男人的天堂久久香蕉 | 天天操天天爽天天射 | 一区二区三区四区欧美 | 99久久国产综合精品国 | 欧洲人体超大胆露私视频 | 午夜不卡在线 | 亚洲精品二区中文字幕 | hs网站在线观看 | 日本妈妈4 | 亚洲免费色视频 | 欧美不卡在线视频 | 国产亚洲综合一区 柠檬导航 | 国产精品手机在线 | 婷婷免费视频 | 国产性较精品视频免费 | 激情婷婷丁香 | 永久黄网站色视频免费 | 色丁香在线观看 | 特黄特色的视频免费播放 | 激情综合色综合久久综合 | 欧美一级三级在线观看 | 88av在线视频 | 亚洲亚洲人成网站在线观看 | 黄色免费看网站 | 一级伦奸视频 | 国模掰开 | 香蕉视频网站在线播放 | 性欧美黑人| 亚洲视频一 | 黄色一级大片视频 | 一区二区在线免费视频 |