同步(Sync)/異步(Async),阻塞(Block)/非阻塞(Unblock)四種調用方式

1. 概念理解ajax

 

     在進行網絡編程時,咱們經常見到同步(Sync)/異步(Async)阻塞(Block)/非阻塞(Unblock)四種調用方式:編程

 

同步/異步主要針對C端: 
同步
      所謂同步,就是在c端發出一個功能調用時,在沒有獲得結果以前,該調用就不返回。也就是必須一件一件事作,等前一件作完了才能作下一件事。瀏覽器

 

例如普通B/S模式(同步):提交請求->等待服務器處理->處理完畢返回 這個期間客戶端瀏覽器不能幹任何事服務器

異步
      異步的概念和同步相對。當c端一個異步過程調用發出後,調用者不能馬上獲得結果。實際處理這個調用的部件在完成後,經過狀態、通知和回調來通知調用者。網絡

     例如 ajax請求(異步): 請求經過事件觸發->服務器處理(這是瀏覽器仍然能夠做其餘事情)->處理完畢異步

 

阻塞/非阻塞主要針對S端: socket

阻塞
     阻塞調用是指調用結果返回以前,當前線程會被掛起(線程進入非可執行狀態,在這個狀態下,cpu不會給線程分配時間片,即線程暫停運行)。函數只有在獲得結果以後纔會返回。ide

 

     有人也許會把阻塞調用和同步調用等同起來,實際上他是不一樣的。對於同步調用來講,不少時候當前線程仍是激活的,只是從邏輯上當前函數沒有返回而已。 例如,咱們在socket中調用recv函數,若是緩衝區中沒有數據,這個函數就會一直等待,直到有數據才返回。而此時,當前線程還會繼續處理各類各樣的消息。函數

   快遞的例子:好比到你某個時候到A樓一層(假如是內核緩衝區)取快遞,可是你不知道快遞何時過來,你又不能幹別的事,只能死等着。但你能夠睡覺(進程處於休眠狀態),由於你知道快遞把貨送來時必定會給你打個電話(假定必定能叫醒你)。spa

 

非阻塞
      非阻塞和阻塞的概念相對應,指在不能馬上獲得結果以前,該函數不會阻塞當前線程,而會馬上返回。

     仍是等快遞的例子:若是用忙輪詢的方法,每隔5分鐘到A樓一層(內核緩衝區)去看快遞來了沒有。若是沒來,當即返回。而快遞來了,就放在A樓一層,等你去取。


對象的阻塞模式和阻塞函數調用
對象是否處於阻塞模式和函數是否是阻塞調用有很強的相關性,可是並非一一對應的。阻塞對象上能夠有非阻塞的調用方式,咱們能夠經過必定的API去輪詢狀 態,在適當的時候調用阻塞函數,就能夠避免阻塞。而對於非阻塞對象,調用特殊的函數也能夠進入阻塞調用。函數select就是這樣的一個例子。

 

1. 同步,就是我客戶端(c端調用者)調用一個功能,該功能沒有結束前,我(c端調用者)死等結果。
2. 異步,就是我(c端調用者)調用一個功能,不須要知道該功能結果,該功能有結果後通知我(c端調用者)即回調通知。

同步/異步主要針對C端, 可是跟S端不是徹底沒有關係,同步/異步機制必須S端配合才能實現. 同步/異步是由c端本身控制, 可是S端是否阻塞/非阻塞, C端徹底不須要關心.


3. 阻塞,      就是調用我(s端被調用者,函數),我(s端被調用者,函數)沒有接收完數據或者沒有獲得結果以前,我不會返回。
4. 非阻塞,  就是調用我(s端被調用者,函數),我(s端被調用者,函數)當即返回,經過select通知調用者


 

同步IO和異步IO的區別就在於:數據訪問的時候進程是否阻塞!

阻塞IO和非阻塞IO的區別就在於:應用程序的調用是否當即返回!

 
同步和異步都只針對於本機SOCKET而言的。

同步和異步,阻塞和非阻塞,有些混用,其實它們徹底不是一回事,並且它們修飾的對象也不相同。
阻塞和非阻塞是指當server端的進程訪問的數據若是還沒有就緒,進程是否須要等待,簡單說這至關於函數內部的實現區別,也就是未就緒時是直接返回仍是等待就緒;

而同步和異步是指client端訪問數據的機制,同步通常指主動請求並等待I/O操做完畢的方式,當數據就緒後在讀寫的時候必須阻塞(區別就緒與讀寫二個階段,同步的讀寫必須阻塞),異步則指主動請求數據後即可以繼續處理其它任務,隨後等待I/O,操做完畢的通知,這可使進程在數據讀寫時也不阻塞。(等待"通知")

相關文章
相關標籤/搜索