BIO、NIO、AIO、多路複用IO的區別(圖解)

原文地址:blog.csdn.net/lzb348110175/article/details/98941378

學習之前,我們先來了解一下IO模型:

       ①同步阻塞IO(Blocking IO):即傳統的IO模型。

       ②同步非阻塞IO(Non-blocking IO):默認創建的socket都是阻塞的,非阻塞IO要求socket被設置爲NONBLOCK。注意這裏所說的NIO並非Java的NIO(New IO)庫。

       ③多路複用IO(IO Multiplexing):即經典的Reactor設計模式,有時也稱爲異步阻塞IO,Java中的Selector和Linux中的epoll都是這種模型(Redis單線程爲什麼速度還那麼快,就是因爲用了多路複用IO和緩存操作的原因)

       ④異步IO(Asynchronous IO):即經典的Proactor設計模式,也稱爲異步非阻塞IO


圖解: 

 

看了這些,你應該對這些IO有了新的認識了吧,那就給我個讚唄^_^


本文分享自微信公衆號 - JAVA高級架構(gaojijiagou)。
如有侵權,請聯繫 [email protected] 刪除。
本文參與“OSC源創計劃”,歡迎正在閱讀的你也加入,一起分享。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章