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