摘要:轉載自在實際應用中,只有三種調用方式同步阻塞同步非阻塞和異步。同步異步同步和異步關注的是消息通信機制。當被調用者獲得結果,會使用其他方式來通知調用者,或者通過回調函數來處理這個調用。然后查好了,他會主動打電話給你回調函數。
轉載自 https://www.zhihu.com/questio...
在實際應用中,只有三種調用方式:同步-阻塞、同步-非阻塞和異步。
同步 (synchronous) vs. 異步 (asynchronous)同步和異步關注的是消息通信機制。
同步:發出一個調用,在沒有得到結果之前,該調用不返回。一旦調用返回,就得到返回值了。
異步:發出一個調用,這個調用就直接返回了,所以沒有返回結果。當被調用者獲得結果,會使用其他方式來通知調用者,或者通過回調函數來處理這個調用。
舉個通俗的例子:
你打電話問書店老板有沒有《分布式系統》這本書。如果是同步通信機制,書店老板會說,你稍等,”我查一下",然后開始查啊查,等查好了(可能是5秒,也可能是一天)告訴你結果(返回結果)。
而異步通信機制,書店老板直接告訴你我查一下啊,查好了打電話給你,然后直接掛電話了(不返回結果)。然后查好了,他會主動打電話給你(回調函數)。
阻塞 (blocking) vs. 非阻塞 (non-blocking)阻塞和非阻塞關注的是程序在等待調用結果時的狀態。
阻塞調用:在調用結果返回之前,當前線程會被掛起。調用線程只有在得到結果之后才會返回。
非阻塞調用:在不能立刻得到結果時,該調用不會阻塞當前線程。
還是上面的例子:
你打電話問書店老板有沒有《分布式系統》這本書。如果是阻塞式調用,你會一直等待,直到得到這本書有沒有的結果。
如果是非阻塞式調用,你不管老板有沒有告訴你,你自己先一邊去玩了。你可能要偶爾過幾分鐘詢問一下老板有沒有返回結果(異步-輪詢),或者讓老板主動打電話來告訴你結果(異步-回調)。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/94687.html
摘要:標準庫中的所有方法都提供非阻塞的異步版本,并接受回調函數,某些方法還具有對應的阻塞方法,其名稱以結尾。比較代碼阻塞方法同步執行,非阻塞方法異步執行。 阻塞與非阻塞概述 此概述介紹了Node.js中阻塞與非阻塞調用之間的區別,此概述將引用事件循環和libuv,但不需要事先了解這些主題,假設讀者對JavaScript語言和Node.js回調模式有基本的了解。 I/O主要指與libuv支持的...
摘要:一閱前熱身為了更加形象的說明同步異步阻塞非阻塞,我們以小明去買奶茶為例。等奶茶做好了,店員喊一聲小明,奶茶好了,然后小明去取奶茶。將響應結果發給相應的連接請求處理完成因為基于,所以每個可以處理無數個連接請求。如此,就輕松的處理了高并發。 一、閱前熱身 為了更加形象的說明同步異步、阻塞非阻塞,我們以小明去買奶茶為例。 1、同步與異步 ①同步與異步的理解 同步與異步的重點在消息通知的方式上...
摘要:一閱前熱身為了更加形象的說明同步異步阻塞非阻塞,我們以小明去買奶茶為例。等奶茶做好了,店員喊一聲小明,奶茶好了,然后小明去取奶茶。將響應結果發給相應的連接請求處理完成因為基于,所以每個可以處理無數個連接請求。如此,就輕松的處理了高并發。 一、閱前熱身 為了更加形象的說明同步異步、阻塞非阻塞,我們以小明去買奶茶為例。 1、同步與異步 ①同步與異步的理解 同步與異步的重點在消息通知的方式上...
摘要:而是在調用發出后,被調用者通過狀態通知來通知調用者,或通過回調函數處理這個調用。請求程序發出請求,從服務器端獲取數據,并設置了回調函數。然后,瀏覽器會設置偵聽來自網絡的響應,拿到數據后,將該回調函數插入到事件循環。 并發與并行 并發是指兩個或多個事件鏈隨時間發展交替執行,以至于從更高的層次來看,就像是同時運行(但在任意時刻只處理一個事件) 并發的關鍵是你有處理多個任務的能力,不一定同...
摘要:最近面試問的比較多的問題就是這一塊了,有些也答出來了,有些答的不好,最近這段時間開始深入了解一些這方面的東西,也想總結一下。 最近面試問的比較多的問題就是IO這一塊了,有些也答出來了,有些答的不好,最近這段時間開始深入了解一些這方面的東西,也想總結一下。 前置點 1,用戶空間系統空間 Linux系統會把一個進程分為兩個空間,用戶空間和系統空間,比如我們正常的編碼,操作的都是用戶空...
閱讀 2628·2021-11-23 09:51
閱讀 2418·2021-09-30 09:48
閱讀 2044·2021-09-22 15:24
閱讀 1009·2021-09-06 15:02
閱讀 3303·2021-08-17 10:14
閱讀 1934·2021-07-30 18:50
閱讀 1980·2019-08-30 15:53
閱讀 3168·2019-08-29 18:43