程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> Java NIO概述

Java NIO概述

編輯:關於JAVA

Java NIO概述。本站提示廣大學習愛好者:(Java NIO概述)文章只能為提供參考,不一定能成為您想要的結果。以下是Java NIO概述正文


Java NIO 由以下幾個中心局部組成:

  • Channels
  • Buffers
  • Selectors

雖然 Java NIO 中除此之外還有很多類和組件,但在我看來,Channel,Buffer 和 Selector 構成了中心的 API。其它組件,如 Pipe 和 FileLock,只不過是與三個中心組件共同運用的工具類。因而,在概述中我將集中在這三個組件上。其它組件會在獨自的章節中講到。

Channel 和 Buffer

根本上,一切的 IO 在 NIO 中都從一個 Channel 開端。Channel 有點象流。 數據可以從 Channel 讀到 Buffer 中,也可以從 Buffer 寫到 Channel 中。這裡有個圖示:

Channel 和 Buffer 有好幾品種型。上面是 JAVA NIO 中的一些次要 Channel 的完成:

  • FileChannel
  • DatagramChannel
  • SocketChannel
  • ServerSocketChannel

正如你所看到的,這些通道涵蓋了 UDP 和 TCP 網絡 IO,以及文件 IO。

與這些類一同的有一些風趣的接口,但為復雜起見,我盡量在概述中不提到它們。本教程其它章節與它們相關的中央我會停止解釋。

以下是 Java NIO 裡關鍵的 Buffer 完成:

  • ByteBuffer
  • CharBuffer
  • DoubleBuffer
  • FloatBuffer
  • IntBuffer
  • LongBuffer
  • ShortBuffer

這些 Buffer 掩蓋了你能經過 IO 發送的根本數據類型:byte,short,int,long,float,double 和 char。

Java NIO 還有個 MappedByteBuffer,用於表示內存映射文件, 我也不計劃在概述中闡明。

Selector

Selector 允許單線程處置多個 Channel。假如你的使用翻開了多個銜接(通道),但每個銜接的流量都很低,運用 Selector 就會很方便。例如,在一個聊天服務器中。

要運用 Selector,得向 Selector 注冊 Channel,然後調用它的 select()辦法。這個辦法會不斷阻塞到某個注冊的通道有事情就緒。一旦這個辦法前往,線程就可以處置這些事情,事情的例子有如新銜接出去,數據接納等。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved