Java NIO概述。本站提示廣大學習愛好者:(Java NIO概述)文章只能為提供參考,不一定能成為您想要的結果。以下是Java NIO概述正文
Java NIO 由以下幾個中心局部組成:
雖然 Java NIO 中除此之外還有很多類和組件,但在我看來,Channel,Buffer 和 Selector 構成了中心的 API。其它組件,如 Pipe 和 FileLock,只不過是與三個中心組件共同運用的工具類。因而,在概述中我將集中在這三個組件上。其它組件會在獨自的章節中講到。
Channel 和 Buffer根本上,一切的 IO 在 NIO 中都從一個 Channel 開端。Channel 有點象流。 數據可以從 Channel 讀到 Buffer 中,也可以從 Buffer 寫到 Channel 中。這裡有個圖示:
Channel 和 Buffer 有好幾品種型。上面是 JAVA NIO 中的一些次要 Channel 的完成:
正如你所看到的,這些通道涵蓋了 UDP 和 TCP 網絡 IO,以及文件 IO。
與這些類一同的有一些風趣的接口,但為復雜起見,我盡量在概述中不提到它們。本教程其它章節與它們相關的中央我會停止解釋。
以下是 Java NIO 裡關鍵的 Buffer 完成:
這些 Buffer 掩蓋了你能經過 IO 發送的根本數據類型:byte,short,int,long,float,double 和 char。
Java NIO 還有個 MappedByteBuffer,用於表示內存映射文件, 我也不計劃在概述中闡明。
SelectorSelector 允許單線程處置多個 Channel。假如你的使用翻開了多個銜接(通道),但每個銜接的流量都很低,運用 Selector 就會很方便。例如,在一個聊天服務器中。
要運用 Selector,得向 Selector 注冊 Channel,然後調用它的 select()辦法。這個辦法會不斷阻塞到某個注冊的通道有事情就緒。一旦這個辦法前往,線程就可以處置這些事情,事情的例子有如新銜接出去,數據接納等。