非同步,同步,阻塞,非阻塞,並行,併發,

2022-09-10 23:54:26 字數 1555 閱讀 2457

老張愛喝茶,廢話不說,煮開水。

出場人物:老張,水壺兩把(普通水壺,簡稱水壺;會響的水壺,簡稱響水壺)。

1 老張把水壺放到火上,立等水開。(同步阻塞)

老張覺得自己有點傻

2 老張把水壺放到火上,去客廳看電視,時不時去廚房看看水開沒有。(同步非阻塞)

老張還是覺得自己有點傻,於是變高階了,買了把會響笛的那種水壺。水開之後,能大聲發出嘀~~~~的噪音。

3 老張把響水壺放到火上,立等水開。(非同步阻塞)

老張覺得這樣傻等意義不大

4 老張把響水壺放到火上,去客廳看電視,水壺響之前不再去看它了,響了再去拿壺。(非同步非阻塞)

老張覺得自己聰明了。

所謂同步非同步,只是對於水壺而言。

普通水壺,同步;響水壺,非同步。

雖然都能幹活,但響水壺可以在自己完工之後,提示老張水開了。這是普通水壺所不能及的。

同步只能讓呼叫者去輪詢自己(情況2中),造成老張效率的低下。

所謂阻塞非阻塞,僅僅對於老張而言。

立等的老張,阻塞;看電視的老張,非阻塞。

情況1和情況3中老張就是阻塞的,媳婦喊他都不知道。雖然3中響水壺是非同步的,可對於立等的老張沒有太大的意義。所以一般非同步是配合非阻塞使用的,這樣才能發揮非同步的效用。

程式設計師寫程式,很多情況下,老張和水壺都要涉及,即呼叫者與被呼叫者。四種組合模式各有所長。

這個例子和銀行排隊有異曲同工之妙,可是我覺得這個會比較容易理解一些。

老張一次比一次聰明,我承認跟老張很像。剛開始的情況邏輯比較簡單,但效率低下。隨著慢慢的提高,效率也提高了。所以個人認為,程式的效率和簡單程度是成反比的。

但不是說非同步非阻塞就一定是最好的,有的情況下更適合使用同步或者阻塞。

併發(concurrency)和並行(parallellism)是:

你吃飯吃到一半,**來了,你一直到吃完了以後才去接,這就說明你不支援併發也不支援並行。

你吃飯吃到一半,**來了,你停了下來接了**,接完後繼續吃飯,這說明你支援併發。

你吃飯吃到一半,**來了,你一邊打**一邊吃飯,這說明你支援並行。

併發是兩個佇列交替使用一台咖啡機,並行是兩個佇列同時使用兩台咖啡機

併發的關鍵是你有處理多個任務的能力,不一定要同時。

並行的關鍵是你有同時處理多個任務的能力。

併發(concurrency)是說程序b的開始時間是在程序a的開始時間與結束時間之間,我們就說a和b是併發的。

並行(parallel execution)是併發的真子集,指同一時間兩個程序執行在不同的機器上或者同乙個機器不同的核心上。

對於單核,多執行緒的多工是在單cpu交替執行,屬於併發;對於多核,多執行緒的任務如果能夠分布在各個cpu

上(執行緒數少許核心數),那麼就是並行,並行是併發的子集

解釋一:並行是指兩個或者多個事件在同一時刻發生;而併發是指兩個或多個事件在同一時間間隔發生。

解釋二:並行是在不同實體上的多個事件,併發是在同一實體上的多個事件

解釋三:在一台處理器上「同時」處理多個任務,在多台處理器上同時處理多個任務。如hadoop分布式集群

同步非同步?阻塞非阻塞?併發並行?

阻塞呼叫是指呼叫結果返回之前,呼叫者會進入阻塞狀態等待。只有在得到結果之後才會返回。非阻塞呼叫是指在不能立刻得到結果之前,該函式不會阻塞當前執行緒,而會立刻返回。同步 在發出乙個同步呼叫時,在沒有得到結果之前,該呼叫就不返回。非同步 在發出乙個非同步呼叫後,呼叫者不會立刻得到結果,該呼叫就返回了。同...

併發 並行,阻塞 非阻塞,同步 非同步

1.阻塞,非阻塞 乙個執行緒 程序經歷的5個狀態,建立,就緒,執行,阻塞,終止。各個狀態的轉換條件如上圖,其中有個阻塞狀態,就是說當執行緒中呼叫某個函式,需要io請求,或者暫時得不到競爭資源的,作業系統會把該執行緒阻塞起來,避免浪費cpu資源,等到得到了資源,再變成就緒狀態,等待cpu排程執行。定義...

同步 非同步 阻塞 非阻塞 併發 並行

同步和非同步關注的是訊息通訊機制 synchronous communication asynchronous communication 所謂同步,就是在發出乙個呼叫時,在沒有得到結果之前,該呼叫就不返回。但是一旦呼叫返回,就得到返回值了。換句話說,就是由呼叫者主動等待這個呼叫的結果。而非同步則是...