日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 >

异步/同步、阻塞/非阻塞的理解

發(fā)布時間:2025/4/16 41 豆豆
生活随笔 收集整理的這篇文章主要介紹了 异步/同步、阻塞/非阻塞的理解 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
異步/同步、阻塞/非阻塞的理解

[同步和異步]

通俗的講:
同步是指:發(fā)送方發(fā)出數(shù)據(jù)后,等接收方發(fā)回響應(yīng)以后才發(fā)下一個數(shù)據(jù)包的通訊方式。?
異步是指:發(fā)送方發(fā)出數(shù)據(jù)后,不等接收方發(fā)回響應(yīng),接著發(fā)送下個數(shù)據(jù)包的通訊方式。
同步:提交請求->等待服務(wù)器處理->處理完畢返回 這個期間客戶端瀏覽器不能干任何事
異步: 請求通過事件觸發(fā)->服務(wù)器處理(這是瀏覽器仍然可以作其他事情)->處理完畢

概念從現(xiàn)實(shí)中來:
同步:打電話,你撥通電話后必須等在那里,直到對方有人接了,你們才能通信或者說你才能繼續(xù)打下一個電話。
異步:發(fā)短信,你可以發(fā)短信,只要你發(fā)出去,你就可以繼續(xù)發(fā)給下一個人,而不需要等到第一個人回你,你才可以繼續(xù)。

同步服務(wù)器
異步服務(wù)器
所謂同步,就是在發(fā)出一個功能調(diào)用時,在沒有得到結(jié)果之前,該調(diào)用就不返回。按照這個定義,其實(shí)絕大多數(shù)函數(shù)都是同步調(diào)用(例如sin, isdigit等)。
但是一般而言,我們在說同步、異步的時候,特指那些需要其他部件協(xié)作或者需要一定時間完成的任務(wù)。最常見的例子就是 SendMessage。
該函數(shù)發(fā)送一個消息給某個窗口,在對方處理完消息之前,這個函數(shù)不返回。當(dāng)對方處理完畢以后,該函數(shù)才把消息處理函數(shù)所返回的 LRESULT值返回給調(diào)用者。

異步
異步的概念和同步相對。當(dāng)一個異步過程調(diào)用發(fā)出后,調(diào)用者不能立刻得到結(jié)果。實(shí)際處理這個調(diào)用的部件在完成后,通過狀態(tài)、通知和回調(diào)來通知調(diào)用者。
以CAsycSocket類為例(注意,CSocket從CAsyncSocket派生,但是起功能已經(jīng)由異步轉(zhuǎn)化為同步),當(dāng)一個客戶端通過調(diào)用 Connect函數(shù)發(fā)出一個連接請求后,
調(diào)用者線程立刻可以朝下運(yùn)行。當(dāng)連接真正建立起來以后,socket底層會發(fā)送一個消息通知該對象。這里提到執(zhí)行部件和調(diào)用者通過三種途徑返回結(jié)果:
狀態(tài)、通知和回調(diào)。可以使用哪一種依賴于執(zhí)行部件的實(shí)現(xiàn),除非執(zhí)行部件提供多種選擇,否則不受調(diào)用者控制。
如果執(zhí)行部件用狀態(tài)來通知,那么調(diào)用者就需要每隔一定時間檢查一次,效率就很低
(有些初學(xué)多線程編程的人,總喜歡用一個循環(huán)去檢查某個變量的值,這其實(shí)是一種很嚴(yán)重的錯誤)。
如果是使用通知的方式,效率則很高,因?yàn)閳?zhí)行部件幾乎不需要做額外的操作。至于回調(diào)函數(shù),其實(shí)和通知沒太多區(qū)別。

[阻塞和非阻塞]

阻塞
阻塞調(diào)用是指調(diào)用結(jié)果返回之前,當(dāng)前線程會被掛起。函數(shù)只有在得到結(jié)果之后才會返回。
有人也許會把阻塞調(diào)用和同步調(diào)用等同起來,實(shí)際上他是不同的。
對于同步調(diào)用來說,很多時候當(dāng)前線程還是激活的,只是從邏輯上當(dāng)前函數(shù)沒有返回而已。
例如,我們在CSocket中調(diào)用Receive函數(shù),如果緩沖區(qū)中沒有數(shù)據(jù),這個函數(shù)就會一直等待,直到有數(shù)據(jù)才返回。
而此時,當(dāng)前線程還會繼續(xù)處理各種各樣的消息。如果主窗口和調(diào)用函數(shù)在同一個線程中,除非你在特殊的界面操作函數(shù)中調(diào)用,其實(shí)主界面還是應(yīng)該可以刷新。
socket接收數(shù)據(jù)的另外一個函數(shù)recv則是一個阻塞調(diào)用的例子。當(dāng)socket工作在阻塞模式的時候,如果沒有數(shù)據(jù)的情況下調(diào)用該函數(shù),則當(dāng)前線程就會被掛起,直到有數(shù)據(jù)為止。

非阻塞
非阻塞和阻塞的概念相對應(yīng),指在不能立刻得到結(jié)果之前,該函數(shù)不會阻塞當(dāng)前線程,而會立刻返回。

通俗地說,你拿著飯碗在排隊(duì)等飯是阻塞的,你不能跑出去干其他事情;你拿著一張取飯的號碼等飯是非阻塞的,你可以出去抽根煙在回來。

比如在epoll模型wait之后,將新連接設(shè)置成一個非阻塞的連接(見epoll模型)
?setnonblocking(client); // 將新連接置于非阻塞模式
這樣客戶端在得到結(jié)果之前,立刻返回,而不是出于等待中。

在網(wǎng)絡(luò)通信與服務(wù)器編程過程中,我們必須首先了解這兩組蛋疼的概念!但是,當(dāng)你模糊時候,請想到
“打電話和發(fā)短信”,“拿飯碗等和拿號碼等飯”,那么你就清楚了!

posted on 2014-10-12 21:03 秦瑞It行程實(shí)錄 閱讀(...) 評論(...) 編輯 收藏

轉(zhuǎn)載于:https://www.cnblogs.com/ruiy/p/4021062.html

總結(jié)

以上是生活随笔為你收集整理的异步/同步、阻塞/非阻塞的理解的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。