NIO是JDK1.4引入的異步IO,NIO核心部分就是三點:
ChannelBufferSelectorNIO與IO的區別,總體上來說體現在三個方面:
IO 基于流(Stream oriented), 而 NIO 基于 Buffer (Buffer oriented)IO 操作是阻塞的, 而 NIO 操作是非阻塞的IO 沒有 selector 概念, 而 NIO 有 selector 概念.傳統的 IO 是面向字節流或字符流的, 而在 NIO 中, 我們拋棄了傳統的 IO 流, 而是引入了 Channel 和 Buffer 的概念。在 NIO 中, 我只能從 Channel 中讀取數據到 Buffer 中或將數據從 Buffer 中寫入到 Channel。
那么什么是 基于流 呢? 在一般的 java IO 操作中, 我們以流式的方式順序地從一個 Stream 中讀取一個或多個字節, 因此我們也就不能隨意改變讀取指針的位置。 而 基于 Buffer 就顯得有點不同了. 我們首先需要從 Channel 中讀取數據到 Buffer 中, 當 Buffer 中有數據后, 我們就可以對這些數據進行操作了。不像 IO 那樣是順序操作, NIO 中我們可以隨意地讀取任意位置的數據。
Java 提供的各種 Stream 操作都是阻塞的, 例如我們調用一個 read 方法讀取一個文件的內容, 那么調用 read 的線程會被阻塞住, 直到 read 操作完成。而 NIO 的非阻塞模式允許我們非阻塞地進行 IO 操作.。例如我們需要從網絡中讀取數據, 在 NIO 的非阻塞模式中, 當我們調用 read 方法時, 如果此時有數據, 則 read 讀取并返回; 如果此時沒有數據, 則 read 直接返回, 而不會阻塞當前線程。
selector 是 NIO 中才有的概念, 它是 Java NIO 之所以可以非阻塞地進行 IO 操作的關鍵。通過 Selector, 一個線程可以監聽多個 Channel 的 IO 事件, 當我們向一個 Selector 中注冊了 Channel 后, Selector 內部的機制就可以自動地為我們不斷地查詢(select) 這些注冊的 Channel 是否有已就緒的 IO 事件(例如可讀, 可寫, 網絡連接完成等)。通過這樣的 Selector 機制, 我們就可以很簡單地使用一個線程高效地管理多個 Channel 了。
新聞熱點
疑難解答