java网络io_彻底搞懂Java的网络IO
該樓層疑似違規已被系統折疊?隱藏此樓查看此樓
java.io包基于流模型實現,提供File抽象、輸入輸出流等IO的功能。交互方式是同步、阻塞的方式,在讀取輸入流或者寫入輸出流時,在讀、寫動作完成之前,線程會一直阻塞。
java.io包的好處是代碼比較簡單、直觀,缺點則是IO效率和擴展性存在局限性,容易成為應用性能的瓶頸。
java.net下面提供的部分網絡API,比如Socket、ServerSocket、HttpURLConnection 也時常被歸類到同步阻塞IO類庫,因為網絡通信同樣是IO行為。
在Java 1.4中引入了NIO框架(java.nio 包),提供了Channel、Selector、Buffer等新的抽象,可以構建多路復用IO程序,同時提供更接近操作系統底層的高性能數據操作方式。
在Java7中,NIO有了進一步的改進,也就是NIO2,引入了異步非阻塞IO方式,也被稱為AIO(Asynchronous IO),異步IO操作基于事件和回調機制。
基本概念
在學習Java的IO流之前,需要了解同步異步、阻塞非阻塞的基本概念。
同步與異步
同步和異步是針對應用程序和內核的交互而言的。
同步指的是用戶進程觸發IO操作并等待或者輪詢的去查看IO操作是否就緒。例如:自己上街買衣服,自己親自干這件事,別的事干不了。
異步指的是用戶進程觸發IO操作以后便開始做其他的事情,而當IO操作已經完成的時候會得到IO完成的通知。例如:告訴朋友自己合適衣服的尺寸、顏色、款式,委托朋友去買,然后自己可以去干別的事。同時,你還需要告訴朋友你家衣柜在哪,方便朋友買完之后,直接將衣服放到你的衣柜。(使用異步I/O時,Java將I/O讀寫委托給OS處理,需要將數據緩沖區地址和大小傳給OS)。
阻塞與非阻塞
阻塞和非阻塞是針對進程在訪問數據的時候,根據IO操作的就緒狀態來采取的不同方式。
阻塞指的是當試圖對該文件描述符進行讀寫時,如果當時沒有東西可讀,或暫時不可寫,程序就進入等待狀態,直到有東西可讀或可寫為止。去地鐵站充值,發現這個時候充值員碰巧不在,然后我們就在原地等待,一直等到充值員回來為止。
非阻塞指的是如果沒有東西可讀,或不可寫,讀寫函數馬上返回,而不會等待。在銀行里辦業務時,領取一張小票,之后我們可以玩手機,或與別人聊聊天,當輪到我們時,銀行的喇叭會通知,這時候我們就可以去辦業務了。
總結
以上是生活随笔為你收集整理的java网络io_彻底搞懂Java的网络IO的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: dcp9020cdn硒鼓!错误_打印机出
- 下一篇: DOM-3 【utils/待讲评】节点属