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