當前位置:
首頁 >
AIO+BIO+NIO+同步+异步+阻塞+非阻塞
發布時間:2023/12/31
47
豆豆
生活随笔
收集整理的這篇文章主要介紹了
AIO+BIO+NIO+同步+异步+阻塞+非阻塞
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
一句話:
AIO是NIO的升級版,NIO是BIO的升級版[1]
所以其實是用AIO
| IO名稱 | JDK版本 | 數據類型 | IO類型 |
| IO | ? | 流 | ? |
| BIO(偶爾也叫做OIO) | <1.4 | ? | 同步阻塞IO |
| NIO | 1.4 | 緩沖 | 同步非阻塞IO |
| AIO(NIO2.0)[7] | 1.7 | ? | 異步非阻塞IO |
?
?
對比[3]如下:
?
然后來說說同步、異步、阻塞非阻塞:
| 概念 | 流程圖 | 備注 |
| 同步阻塞IO | 針對Sender而言,請求發送出去以后,一直等到Receiver有結果了才返回,這是同步。在Sender獲取結果的期間一直被block住了,也就是在此期間Sender不能處理其它事情,這是阻塞。 | |
| 異步阻塞IO | 針對Sender而言,請求發送出去以后,立刻返回,然后再等待Receiver的callback,最后再次請求獲取response,這整個過程是異步。在Sender等待Receiver的callback期間一直被block住了,也就是在此期間Sender不能處理其它事情,這是阻塞。 | |
| 同步非阻塞IO | 針對Sender而言,請求發送出去以后,立刻返回,然后再不停的發送請求,直到Receiver處理好結果后,最后一次發請求給Receiver才獲得response。Sender一直在主動輪詢,每一個請求都是同步的,整個過程也是同步的。在Sender等待Receiver的response期間一直是可以處理其它事情的(比如:可以發送請求詢問結果),這是非阻塞。 | |
| 異步非阻塞IO | 針對Sender而言,請求發送出去以后,立刻返回,然后再等待Receiver的callback,最后再次請求獲取response,這整個過程是異步。在Sender等待Receiver的callback期間一直是可以處理其它事情的,這是非阻塞。 |
?
記憶的時候,上面的四種情況重點記憶“阻塞和非阻塞”極客
上面四種情況可以知道性能上的最佳方式是:異步阻塞IO和異步非阻塞IO
?
兩種I/O多路復用模式:
| 模式 | 原理 | 應用場景 | 舉例 |
| reactor | Linux epoll | 同步IO | callback |
| proactor | Windows IO completion port | 異步IO | future/await |
?
基本 Linux I/O 模型的簡單矩陣[6]:
?
Reference:
[1]Java核心(五)深入理解BIO、NIO、AIO
[2]簡述JAVA同步、異步、阻塞和非阻塞之間的區別
[3]Java AIO 基本介紹
[4]如何深刻理解Reactor和Proactor?
[5]java-IO-多路復用機制
[6]Java新一代網絡編程模型AIO原理及Linux系統AIO介紹
[7]淺析Java 中的流--BIO、NIO、AIO及NIO中的三大組件Buffer,Channel,Selector
創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的AIO+BIO+NIO+同步+异步+阻塞+非阻塞的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 免费保险是什么套路
- 下一篇: Error while compilin