“阻塞”與"非阻塞"與"同步"與“異步"不能簡單的從字面理解,提供一個從分布式系統(tǒng)角度的回答。
1.同步與異步同步和異步關(guān)注的是消息通信機制 (synchronous communication/ asynchronous communication)所謂同步贼陶,就是在發(fā)出一個調(diào)用時,在沒有得到結(jié)果之前巧娱,該調(diào)用就不返回碉怔。但是一旦調(diào)用返回,就得到返回值了禁添。換句話說撮胧,就是由調(diào)用者主動等待這個調(diào)用的結(jié)果。而異步則是相反老翘,調(diào)用在發(fā)出之后芹啥,這個調(diào)用就直接返回了,所以沒有返回結(jié)果酪捡。換句話說,當一個異步過程調(diào)用發(fā)出后纳账,調(diào)用者不會立刻得到結(jié)果逛薇。而是在調(diào)用發(fā)出后,被調(diào)用者通過狀態(tài)疏虫、通知來通知調(diào)用者永罚,或通過回調(diào)函數(shù)處理這個調(diào)用啤呼。典型的異步編程模型比如Node.js舉個通俗的例子:你打電話問書店老板有沒有《分布式系統(tǒng)》這本書,如果是同步通信機制呢袱,書店老板會說官扣,你稍等,”我查一下"羞福,然后開始查啊查惕蹄,等查好了(可能是5秒,也可能是一天)告訴你結(jié)果(返回結(jié)果)治专。而異步通信機制卖陵,書店老板直接告訴你我查一下啊,查好了打電話給你张峰,然后直接掛電話了(不返回結(jié)果)泪蔫。然后查好了,他會主動打電話給你喘批。在這里老板通過“回電”這種方式來回調(diào)撩荣。
2. 阻塞與非阻塞阻塞和非阻塞關(guān)注的是程序在等待調(diào)用結(jié)果(消息,返回值)時的狀態(tài).阻塞調(diào)用是指調(diào)用結(jié)果返回之前饶深,當前線程會被掛起餐曹。調(diào)用線程只有在得到結(jié)果之后才會返回。非阻塞調(diào)用指在不能立刻得到結(jié)果之前粥喜,該調(diào)用不會阻塞當前線程凸主。還是上面的例子,你打電話問書店老板有沒有《分布式系統(tǒng)》這本書额湘,你如果是阻塞式調(diào)用卿吐,你會一直把自己“掛起”,直到得到這本書有沒有的結(jié)果锋华,如果是非阻塞式調(diào)用嗡官,你不管老板有沒有告訴你,你自己先一邊去玩了毯焕, 當然你也要偶爾過幾分鐘check一下老板有沒有返回結(jié)果衍腥。在這里阻塞與非阻塞與是否同步異步無關(guān)。跟老板通過什么方式回答你結(jié)果無關(guān)纳猫。
老張愛喝茶婆咸,廢話不說,煮開水芜辕。出場人物:老張尚骄,水壺兩把(普通水壺,簡稱水壺侵续;會響的水壺倔丈,簡稱響水壺)憨闰。
1 老張把水壺放到火上,立等水開需五。(同步阻塞)老張覺得自己有點傻
2 老張把水壺放到火上鹉动,去客廳看電視,時不時去廚房看看水開沒有宏邮。(同步非阻塞)老張還是覺得自己有點傻泽示,于是變高端了,買了把會響笛的那種水壺蜀铲。水開之后边琉,能大聲發(fā)出嘀~~~~的噪音。
3 老張把響水壺放到火上记劝,立等水開变姨。(異步阻塞)老張覺得這樣傻等意義不大
4 老張把響水壺放到火上,去客廳看電視厌丑,水壺響之前不再去看它了定欧,響了再去拿壺。(異步非阻塞)老張覺得自己聰明了怒竿。
所謂同步異步砍鸠,只是對于水壺而言。普通水壺耕驰,同步爷辱;響水壺,異步朦肘。雖然都能干活饭弓,但響水壺可以在自己完工之后,提示老張水開了媒抠。這是普通水壺所不能及的弟断。
同步只能讓調(diào)用者去輪詢自己(情況2中),造成老張效率的低下趴生。所謂阻塞非阻塞阀趴,僅僅對于老張而言。立等的老張苍匆,阻塞刘急;看電視的老張,非阻塞浸踩。情況1和情況3中老張就是阻塞的叔汁,媳婦喊他都不知道。雖然3中響水壺是異步的,可對于立等的老張沒有太大的意義攻柠。
所以一般異步是配合非阻塞使用的,這樣才能發(fā)揮異步的效用后裸。
——來源網(wǎng)絡(luò)瑰钮,作者不明。