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

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

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

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

操作系統(tǒng)上并行和并發(fā)的區(qū)別

科技綠洲 ? 來源:Linux開發(fā)架構(gòu)之路 ? 作者:Linux開發(fā)架構(gòu)之路 ? 2023-11-09 14:42 ? 次閱讀

理解并發(fā)、并行的例子

先舉例子來理解這2個概念的區(qū)別。

老師讓兩個同學(xué)去辦公室談話。如果這兩同學(xué)(進(jìn)程)是并列跨過辦公室門(CPU)的,那么就是并行。如果同學(xué)A先進(jìn)同學(xué)B后進(jìn)入(或者先B后A),或者兩人并列同時進(jìn)入,但是在辦公室外的路人甲(用戶)看來,同學(xué)A和同學(xué)B同時都在辦公室內(nèi),這是并發(fā)。

圖片

其實這個例子不合理,因為真正的并行是多核CPU下的概念,但上面這個簡單的例子非常有助于理解。

如果舉例要精確一點(diǎn),那么大概是這樣的:進(jìn)辦公室有兩個門(兩CPU),如果兩同學(xué)分別從不同的門進(jìn)入,不管先后性,兩者互相獨(dú)立,那么是并行;如果兩同學(xué)不管以什么方式進(jìn)入,在路人甲看來,他兩同時都在辦公室內(nèi),就是并發(fā)。

圖片

我不信到現(xiàn)在還不理解并發(fā)和并行。

并發(fā)和并行的理論性解釋

為什么操作系統(tǒng)上可以同時運(yùn)行多個程序而用戶感覺不出來?

這是因為無論是單CPU還是多CPU,操作系統(tǒng)都營造出了可以同時運(yùn)行多個程序的假象。實際的過程操作系統(tǒng)對進(jìn)程的調(diào)度以及CPU的快速上下文切換實現(xiàn)的:每個進(jìn)程執(zhí)行一會就先停下來,然后CPU切換到下個被操作系統(tǒng)調(diào)度到的進(jìn)程上使之運(yùn)行。因為切換的很快,使得用戶認(rèn)為操作系統(tǒng)一直在服務(wù)自己的程序。

再來解釋并發(fā)就容易理解多了。

并發(fā)(concurrent)指的是多個程序可以同時運(yùn)行的現(xiàn)象,更細(xì)化的是多進(jìn)程可以同時運(yùn)行或者多指令可以同時運(yùn)行。但這不是重點(diǎn),在描述并發(fā)的時候也不會去扣這種字眼是否精確,并發(fā)的重點(diǎn)在于它是一種現(xiàn)象。并發(fā)描述的是多進(jìn)程同時運(yùn)行的現(xiàn)象。但實際上,對于單核心CPU來說,同一時刻只能運(yùn)行一個進(jìn)程。所以,這里的"同時運(yùn)行"表示的不是真的同一時刻有多個進(jìn)程運(yùn)行的現(xiàn)象,這是并行的概念,而是提供一種功能讓用戶看來多個程序同時運(yùn)行起來了,但實際上這些程序中的進(jìn)程不是一直霸占CPU的,而是執(zhí)行一會停一會。

所以,并發(fā)和并行的區(qū)別就很明顯了。它們雖然都說是"多個進(jìn)程同時運(yùn)行",但是它們的"同時"不是一個概念。并行的"同時"是同一時刻可以多個進(jìn)程在運(yùn)行(處于running),并發(fā)的"同時"是經(jīng)過上下文快速切換,使得看上去多個進(jìn)程同時都在運(yùn)行的現(xiàn)象,是一種OS欺騙用戶的現(xiàn)象。

實際上,當(dāng)程序中寫下多進(jìn)程或多線程代碼時,這意味著的是并發(fā)而不是并行。并發(fā)是因為多進(jìn)程/多線程都是需要去完成的任務(wù),不并行是因為并行與否由操作系統(tǒng)的調(diào)度器決定,可能會讓多個進(jìn)程/線程被調(diào)度到同一個CPU核心上。只不過調(diào)度算法會盡量讓不同進(jìn)程/線程使用不同的CPU核心,所以在實際使用中幾乎總是會并行,但卻不能以100%的角度去保證會并行。也就是說,并行與否程序員無法控制,只能讓操作系統(tǒng)決定。

再次注明,并發(fā)是一種現(xiàn)象,之所以能有這種現(xiàn)象的存在,和CPU的多少無關(guān),而是和進(jìn)程調(diào)度以及上下文切換有關(guān)的。

理解了概念,再來深入擴(kuò)展下。

串行、并行和并發(fā)

任務(wù)描述

如圖:

圖片

任務(wù)是將左邊的一堆柴全部搬到右邊燒掉,每個任務(wù)包括三個過程:取柴,運(yùn)柴,放柴燒火。

這三個過程分別對應(yīng)一個函數(shù):

func get { geting }
func carry { carrying }
func unload { unloading }

串行模式

串行表示所有任務(wù)都一一按先后順序進(jìn)行。串行意味著必須先裝完一車柴才能運(yùn)送這車柴,只有運(yùn)送到了,才能卸下這車柴,并且只有完成了這整個三個步驟,才能進(jìn)行下一個步驟。

和稍后所解釋的并行相對比,串行是一次只能取得一個任務(wù),并執(zhí)行這個任務(wù)。

假設(shè)這堆柴需要運(yùn)送4次才能運(yùn)完,那么當(dāng)寫下的代碼類似于下面這種時,那么就是串行非并發(fā)的模式:

for(i=0;i<4;i++){
get()
carry()
unload()
}

或者,將三個過程的代碼全部集中到一個函數(shù)中也是如此:

func task {
geting
carrying
unloading
}

for(i=0;i<4;i++){
task()
}

這兩種都是串行的代碼模式。畫圖描述:

圖片

并行模式

并行意味著可以同時取得多個任務(wù),并同時去執(zhí)行所取得的這些任務(wù)。并行模式相當(dāng)于將長長的一條隊列,劃分成了多條短隊列,所以并行縮短了任務(wù)隊列的長度。

正如前面所舉的兩同學(xué)進(jìn)辦公室的例子,串行的方式下,必須1個同學(xué)進(jìn)入后第二個同學(xué)才進(jìn)入,隊列長度為2,而并行方式下可以同時進(jìn)入,隊列長度減半了。

并行的效率從代碼層次上強(qiáng)依賴于多進(jìn)程/多線程代碼,從硬件角度上則依賴于多核CPU。

對于單進(jìn)程/單線程,由于只有一個進(jìn)程/線程在執(zhí)行,所以盡管同時執(zhí)行所取得的多個任務(wù),但實際上這個進(jìn)程/線程是不斷的在多任務(wù)之間切換,一會執(zhí)行一下這個,一會執(zhí)行一下那個,就像是一個人在不同地方之間來回奔波。所以,單進(jìn)程/線程的并行,效率比串行更低。

對于多進(jìn)程/多線程,各進(jìn)程/線程都可以執(zhí)行各自所取得的任務(wù),這是真正的并行。

但是,還需要考慮硬件層次上CPU核心數(shù),如果只有單核CPU,那么在硬件角度上這單核CPU一次也只能執(zhí)行一個任務(wù),上面多進(jìn)程/多線程的并行也并非真正意義上的并行。只有多核CPU,并且多進(jìn)程/多線程并行,才是真正意義上的并行。

如下圖,是多進(jìn)程/多線程(2個工作者)的并行:

圖片

并發(fā)

并發(fā)表示多個任務(wù)同時都要執(zhí)行的現(xiàn)象,更詳細(xì)的概念前面已經(jīng)說面的夠具體了。

其實,很多場景下都會使用并發(fā)的概念。比如同時500個http請求涌向了web服務(wù)器,比如有時候說并發(fā)數(shù)是1000等。

有時候也將并發(fā)當(dāng)成任務(wù),比如500并發(fā)數(shù)意味著500個任務(wù),表示的是在一個特定的時間段內(nèi)(約定俗成的大家認(rèn)為是1秒)可以完成500個任務(wù)。這500個任務(wù)可以是單進(jìn)程/單線程方式處理的,這時表示的是并發(fā)不并行的模式(coroutine就是典型的并發(fā)不并行),即先執(zhí)行完一個任務(wù)后才執(zhí)行另一個任務(wù),也可以是多進(jìn)程/多線程方式處理的,這時表示的是并發(fā)且并行模式。

要解決大并發(fā)問題,通常是將大任務(wù)分解成多個小任務(wù)。很典型的一個例子是處理客戶端的請求任務(wù),這個大任務(wù)里面包含了監(jiān)聽并建立客戶端的連接、處理客戶端的請求、響應(yīng)客戶端。但基本上所有這類程序,都將這3部分任務(wù)分開了:在執(zhí)行任何一個小任務(wù)的時候,都可以通過一些手段使得可以執(zhí)行其它小任務(wù),比如在處理請求的時候,可以繼續(xù)保持監(jiān)聽狀態(tài)。

由于操作系統(tǒng)對進(jìn)程的調(diào)度是隨機(jī)的,所以切分成多個小任務(wù)后,可能會從任一小任務(wù)處執(zhí)行。這可能會出現(xiàn)一些現(xiàn)象:

  • 可能出現(xiàn)一個小任務(wù)執(zhí)行了多次,還沒開始下個任務(wù)的情況。這時一般會采用隊列或類似的數(shù)據(jù)結(jié)構(gòu)來存放各個小任務(wù)的成果。比如負(fù)責(zé)監(jiān)聽的進(jìn)程已經(jīng)執(zhí)行了多次,建立了多個連接,但是還沒有調(diào)度到處理請求的進(jìn)程去處理任何一個請求。
  • 可能出現(xiàn)還沒準(zhǔn)備好第一步就執(zhí)行第二步的可能。這時,一般采用多路復(fù)用或異步的方式,比如只有準(zhǔn)備好產(chǎn)生了事件通知才執(zhí)行某個任務(wù)。比如還沒有和任何一個客戶端建立連接時,就去執(zhí)行了處理請求的進(jìn)程。
  • 可以多進(jìn)程/多線程的方式并行執(zhí)行這些小任務(wù)。也可以單進(jìn)程/單線程執(zhí)行這些小任務(wù),這時很可能要配合多路復(fù)用才能達(dá)到較高的效率

看圖非常容易理解:

圖片

上圖中將一個任務(wù)中的三個步驟取柴、運(yùn)柴、卸柴劃分成了獨(dú)立的小任務(wù),有取柴的老鼠,有運(yùn)柴的老鼠,有卸柴燒火的老鼠。

如果上圖中所有的老鼠都是同一只,那么是串行并發(fā)的,如果是不同的多只老鼠,那么是并行并發(fā)的。

總結(jié)

并行和串行:

  • 串行:一次只能取得一個任務(wù)并執(zhí)行這一個任務(wù)
  • 并行:可以同時通過多進(jìn)程/多線程的方式取得多個任務(wù),并以多進(jìn)程或多線程的方式同時執(zhí)行這些任務(wù)
  • 注意點(diǎn):
  • 如果是單進(jìn)程/單線程的并行,那么效率比串行更差
  • 如果只有單核cpu,多進(jìn)程并行并沒有提高效率
  • 從任務(wù)隊列上看,由于同時從隊列中取得多個任務(wù)并執(zhí)行,相當(dāng)于將一個長任務(wù)隊列變成了短隊列

并發(fā):

  • 并發(fā)是一種現(xiàn)象:同時運(yùn)行多個程序或多個任務(wù)需要被處理的現(xiàn)象
  • 這些任務(wù)可能是并行執(zhí)行的,也可能是串行執(zhí)行的,和CPU核心數(shù)無關(guān),是操作系統(tǒng)進(jìn)程調(diào)度和CPU上下文切換達(dá)到的結(jié)果
  • 解決大并發(fā)的一個思路是將大任務(wù)分解成多個小任務(wù):
  • 可能要使用一些數(shù)據(jù)結(jié)構(gòu)來避免切分成多個小任務(wù)帶來的問題
  • 可以多進(jìn)程/多線程并行的方式去執(zhí)行這些小任務(wù)達(dá)到高效率
  • 或者以單進(jìn)程/單線程配合多路復(fù)用執(zhí)行這些小任務(wù)來達(dá)到高效率
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • cpu
    cpu
    +關(guān)注

    關(guān)注

    68

    文章

    11049

    瀏覽量

    216129
  • 操作系統(tǒng)
    +關(guān)注

    關(guān)注

    37

    文章

    7103

    瀏覽量

    125041
  • 并行
    +關(guān)注

    關(guān)注

    0

    文章

    80

    瀏覽量

    19230
  • 程序
    +關(guān)注

    關(guān)注

    117

    文章

    3824

    瀏覽量

    82498
收藏 人收藏

    評論

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

    實時操作系統(tǒng)和分時操作系統(tǒng)區(qū)別

    操作系統(tǒng)能否滿足實時性要求來區(qū)分,可把操作系統(tǒng)分成分時操作系統(tǒng)和實時操作系統(tǒng),分時操作系統(tǒng)按照相等的時間片調(diào)度進(jìn)程輪流運(yùn)行,分時操作系統(tǒng)
    發(fā)表于 11-14 17:39 ?1.3w次閱讀

    Linux與其他操作系統(tǒng)區(qū)別

    Linux與其他操作系統(tǒng)區(qū)別Linux與其他操作系統(tǒng)區(qū)別  Linux可以與MS-DOS、OS/2、Windows等其他操作系統(tǒng)共存于同
    發(fā)表于 09-13 10:12

    POS機(jī)的linux操作系統(tǒng)和android系統(tǒng)區(qū)別

    其實兩個系統(tǒng)之間區(qū)別也有各自的使用場景,如:收款機(jī)、收印機(jī)在這個產(chǎn)品兩個系統(tǒng)都可以使用,但是目前l(fā)inux系統(tǒng)在這個方面使用比較多,缺點(diǎn)是
    發(fā)表于 01-03 11:21

    Java操作系統(tǒng)支持多線程

    Windows等操作系統(tǒng)均支持多線程進(jìn)程的并發(fā)處理機(jī)制。操作系統(tǒng)支持多線程,使多個程序能夠并發(fā)執(zhí)行,以改善資源使用率和提高系統(tǒng)效率;
    發(fā)表于 08-05 06:06

    操作系統(tǒng)的特點(diǎn)?

    操作系統(tǒng)操作系統(tǒng)的特點(diǎn)?– 共享:資源可被多個并發(fā)執(zhí)行的進(jìn)程使用– 并發(fā):可以在同一時間間隔處理多個進(jìn)程,需要硬件支持– 虛擬:將物理實體映射成為多個虛擬設(shè)備– 異步:進(jìn)程執(zhí)行走走停停
    發(fā)表于 07-22 09:18

    uCOS-II實時操作系統(tǒng)實時操作系統(tǒng)與分時操作系統(tǒng)區(qū)別是什么

    文章目錄1簡介1uCOS-II中的任務(wù)1簡介uCOS-II實時操作系統(tǒng)實時操作系統(tǒng)與分時操作系統(tǒng)區(qū)別:分時操作系統(tǒng)將時間一塊一塊的分給不同
    發(fā)表于 12-14 06:42

    實時操作系統(tǒng)和Linux分時操作系統(tǒng)有哪些區(qū)別

    什么是單片機(jī)?什么是嵌入式呢?實時操作系統(tǒng)和Linux分時操作系統(tǒng)有哪些區(qū)別呢?
    發(fā)表于 01-24 07:36

    裸機(jī)與帶嵌入式開發(fā)的操作系統(tǒng)有何區(qū)別

    、RT-Thread 、eCos和Linux等。2.區(qū)別馬克思主義認(rèn)為,事物之間是相互聯(lián)系和相互區(qū)別的。帶操作系統(tǒng)開發(fā)由于操作系統(tǒng)具有并發(fā)
    發(fā)表于 02-14 07:28

    操作系統(tǒng)講解(操作系統(tǒng)課件)

    操作系統(tǒng)講解(操作系統(tǒng)課件) 第五章 文件管理.doc第六章 設(shè)備管理(部分).doc第二章 進(jìn)程管理.doc第3章 并發(fā)控制——互斥與同步.doc操作系統(tǒng)---進(jìn)程間通信.ppt
    發(fā)表于 05-16 18:06 ?0次下載

    Linux與其他操作系統(tǒng)區(qū)別

    Linux與其他操作系統(tǒng)區(qū)別 Linux與其他操作系統(tǒng)區(qū)別  Linux可以與MS-DOS、OS/2、Windows等其他操作系統(tǒng)共存
    發(fā)表于 01-18 12:42 ?1729次閱讀

    并行并發(fā)哪個好?并行并發(fā)的概念和區(qū)別

    摘要:并發(fā)并行是兩個既相似而又不相同的概念:并發(fā)性,又稱共行性,是指能處理多個同時性活動的能力;并行是指同時發(fā)生的兩個并發(fā)事件,具有
    發(fā)表于 12-08 09:12 ?6.6w次閱讀
    <b class='flag-5'>并行</b>和<b class='flag-5'>并發(fā)</b>哪個好?<b class='flag-5'>并行</b>和<b class='flag-5'>并發(fā)</b>的概念和<b class='flag-5'>區(qū)別</b>

    Linux操作系統(tǒng)與Windows操作系統(tǒng)的五大區(qū)別

    Linux操作系統(tǒng)和Windows操作系統(tǒng)身為三大操作系統(tǒng)巨頭里面的兩大巨頭,他們有什么區(qū)別呢?首先,先要聲明一點(diǎn),所有以Linux內(nèi)核為基礎(chǔ)開發(fā)的
    發(fā)表于 07-10 16:28 ?8139次閱讀

    實時操作系統(tǒng)和非實時操作系統(tǒng)區(qū)別

    本文主要闡述了實時操作系統(tǒng)和非實時操作系統(tǒng)區(qū)別
    發(fā)表于 09-02 15:58 ?1.1w次閱讀

    裸機(jī)開發(fā)和帶操作系統(tǒng)開發(fā)的區(qū)別

    、RT-Thread 、eCos和Linux等。2.區(qū)別馬克思主義認(rèn)為,事物之間是相互聯(lián)系和相互區(qū)別的。帶操作系統(tǒng)開發(fā)由于操作系統(tǒng)具有并發(fā)
    發(fā)表于 12-09 12:51 ?24次下載
    裸機(jī)開發(fā)和帶<b class='flag-5'>操作系統(tǒng)</b>開發(fā)的<b class='flag-5'>區(qū)別</b>

    嵌入式實時操作系統(tǒng):Intewell操作系統(tǒng)與VxWorks操作系統(tǒng)有啥區(qū)別

    Intewell操作系統(tǒng)和VxWorks操作系統(tǒng)都是工業(yè)領(lǐng)域常用的操作系統(tǒng),它們各有特點(diǎn)和優(yōu)勢。以下是它們之間的一些主要區(qū)別
    的頭像 發(fā)表于 07-08 14:16 ?734次閱讀
    嵌入式實時<b class='flag-5'>操作系統(tǒng)</b>:Intewell<b class='flag-5'>操作系統(tǒng)</b>與VxWorks<b class='flag-5'>操作系統(tǒng)</b>有啥<b class='flag-5'>區(qū)別</b>
    主站蜘蛛池模板: 最新四虎4hu影库地址在线 | 国产综合在线观看视频 | 97人人视频| 又粗又长又爽又长黄免费视频 | 色多多18免费观看 | 一级做a爰片久久免费 | 狠狠色噜噜狠狠色综合久 | 男女免费在线视频 | 国产精品美女免费视频观看 | 久久精品视频免费播放 | 香蕉免费在线视频 | www.av片| xxxx欧美| 末成年一级在线看片 | 日本黄色大片在线观看 | 四虎永久影院 | 天天躁天天爽 | 三级理论在线 | 中文久草| 艹逼视频免费看 | 天堂va欧美ⅴa亚洲va一国产 | 国产欧美精品一区二区色综合 | 天天在线精品视频在线观看 | 免费网站你懂得 | 免费看一级特黄a大片 | 五月天色婷婷丁香 | 激情婷婷综合久久久久 | 天堂资源在线最新版 | 亚洲国产欧美视频 | xxx69日本hd| 美女视频黄的免费视频网页 | 久久国产午夜精品理论篇小说 | 毛茸茸成熟妇女亚洲人 | 中文字幕在线一区 | 色日本在线 | 久草在线资源网 | 香焦视频在线观看黄 | 1024毛片基地| 人人射人人澡 | 免费看一级大片 | 亚洲国内精品久久 |