Java中網(wǎng)絡(luò)IO的實(shí)現(xiàn)方式(BIO、NIO、AIO)介紹
在網(wǎng)絡(luò)編程中,接觸到最多的就是利用Socket進(jìn)行網(wǎng)絡(luò)通信開(kāi)發(fā)。在Java中主要是以下三種實(shí)現(xiàn)方式BIO、NIO、AIO。
關(guān)于這三個(gè)概念的辨析以前一直都是好像懂,但是表達(dá)的不是很清楚,下面做個(gè)總結(jié)完全辨析清楚。
1. BIO方式
首先我用一個(gè)較為通俗的語(yǔ)言來(lái)說(shuō)明:
BIO 就是阻塞IO,每個(gè)TCP連接進(jìn)來(lái)服務(wù)端都需要?jiǎng)?chuàng)建一個(gè)線程來(lái)建立連接并進(jìn)行消息的處理。如果中間發(fā)生了阻塞(比如建立連接、讀數(shù)據(jù)、寫(xiě)數(shù)據(jù)時(shí)發(fā)生阻礙),線程也會(huì)發(fā)生阻塞,并發(fā)情況下,N個(gè)連接需要N個(gè)線程來(lái)處理。
這種方式的缺點(diǎn)就是:并發(fā)情況下效率很低。
下面用一個(gè)圖示來(lái)說(shuō)明BIO的工作情況

2. NIO方式
NIO是JDK1.4提出的,還是先用一段通俗的話來(lái)說(shuō)明NIO的工作原理:
NIO 也就是非阻塞IO,是基于事件驅(qū)動(dòng)的思想(Reactor線程模型)。對(duì)比與BIO來(lái)說(shuō),NIO使用一個(gè)線程來(lái)管理所有的Socket 通道,也就是基于Selector機(jī)制,當(dāng)查詢到事件時(shí)(連接、接受連接、讀、寫(xiě)),就會(huì)轉(zhuǎn)發(fā)給不同的處理線程(handler)。
下面給出Reactor模型的工作應(yīng)用圖:

3. AIO方式
AIO是JDK1.7提出的,也就是異步IO。AIO采用的是Proactor模式。我們首先應(yīng)該辨析的是AIO和NIO的區(qū)別:
(1)NIO的通知是發(fā)生在Handler之前;
(2)AIO的通知是發(fā)生在讀寫(xiě)等處理之后的回調(diào),有通知時(shí)表示相關(guān)操作已經(jīng)結(jié)束了。
AIO在進(jìn)行讀寫(xiě)操作時(shí),只需要調(diào)用相應(yīng)的read/write方法,并傳入CompletionHandler(動(dòng)作完成時(shí)處理器),在動(dòng)作完成后會(huì)調(diào)用CompletionHandler。 NIO的通知是發(fā)生在動(dòng)作之前,是在可讀可寫(xiě)的時(shí)候,Selector發(fā)現(xiàn)了這些事件后就通知并調(diào)用Handler處理,
下面給出Proactor模式的工作流程圖:

感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
- 淺談Java中BIO、NIO和AIO的區(qū)別和應(yīng)用場(chǎng)景
- 詳解Java 網(wǎng)絡(luò)IO編程總結(jié)(BIO、NIO、AIO均含完整實(shí)例代碼)
- Java中AIO、BIO、NIO應(yīng)用場(chǎng)景及區(qū)別
- Java中BIO、NIO、AIO的理解
- java的三種IO模型詳解(BIO、NIO、AIO)
- Java?IO模型之BIO、NIO、AIO三種常見(jiàn)IO模型解析
- java中BIO、NIO、AIO都有啥區(qū)別
- Java網(wǎng)絡(luò)IO模型詳解(BIO、NIO、AIO)
- Java中BIO、NIO和AIO的區(qū)別、原理與用法
- 一文徹底搞懂Java BIO、NIO、AIO的核心區(qū)別
相關(guān)文章
springmvc使用REST出現(xiàn):Request?method?'PUT'?not?sup
這篇文章主要介紹了springmvc使用REST出現(xiàn):Request?method?'PUT'?not?supported問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02
mybatis insert foreach循環(huán)插入方式
這篇文章主要介紹了mybatis insert foreach循環(huán)插入方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07
使用HttpClient調(diào)用接口的實(shí)例講解
下面小編就為大家?guī)?lái)一篇使用HttpClient調(diào)用接口的實(shí)例講解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-10-10
Java連接Oracle數(shù)據(jù)庫(kù)并查詢
這篇文章主要介紹了Java連接Oracle數(shù)據(jù)庫(kù)并查詢的相關(guān)資料,需要的朋友可以參考下2017-04-04
oracle數(shù)據(jù)庫(kù)導(dǎo)入TXT文件方法介紹
這篇文章主要介紹了oracle數(shù)據(jù)庫(kù)導(dǎo)入TXT文件方法介紹,文中向大家展示了具體代碼示例,需要的朋友可以參考下。2017-09-09
MybatisPlus實(shí)現(xiàn)真正批量插入的詳細(xì)步驟
在數(shù)據(jù)庫(kù)操作中,批量插入是提升效率的重要手段,MyBatis-Plus提供了多種批量插入方法,但默認(rèn)的saveBatch方法效率并不高,文章介紹了通過(guò)手動(dòng)拼接SQL、使用IService接口以及自定義insertBatchSomeColumn方法進(jìn)行優(yōu)化,以實(shí)現(xiàn)更高效的批量插入,并給出了性能優(yōu)化建議2024-10-10
Java BigDecimal詳解_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
BigDecimal 由任意精度的整數(shù)非標(biāo)度值 和32 位的整數(shù)標(biāo)度 (scale) 組成。接下來(lái)通過(guò)本文給大家介紹Java BigDecimal詳解,需要的的朋友參考下吧2017-04-04
spring事務(wù)的propagation傳播屬性示例詳解
這篇文章主要為大家介紹了spring事務(wù)的propagation傳播屬性示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09
Java?SimpleDateFormat與System類使用示例詳解
這篇文章主要介紹了Java?SimpleDateFormat與System類使用示例,對(duì)于SimpleDateFormat類,是一個(gè)用來(lái)區(qū)分區(qū)域設(shè)置的方式進(jìn)行日期的是指,以及對(duì)日期進(jìn)行處理分析的一個(gè)實(shí)現(xiàn)類2022-11-11

