Java NIO系列教程(二) Channel

Java NIO的通道類似流,但又有些不同:

  • 既可以從通道中讀取數據,又可以寫數據到通道。但流的讀寫通常是單向的。
  • 通道可以異步地讀寫。
  • 通道中的數據總是要先讀到一個Buffer,或者總是要從一個Buffer中寫入。

正如上面所說,從通道讀取數據到緩衝區,從緩衝區寫入數據到通道。如下圖所示:

Channel的實現

這些是Java NIO中最重要的通道的實現:

  • FileChannel  從文件中讀寫數據;
  • DatagramChannel  能通過UDP讀寫網絡中的數據;
  • SocketChannel  能通過TCP讀寫網絡中的數據;
  • ServerSocketChannel  可以監聽新進來的TCP連接,像Web服務器那樣。對每一個新進來的連接都會創建一個SocketChannel。

基本的 Channel 示例

下面是一個使用FileChannel讀取數據到Buffer中的示例:

RandomAccessFile aFile = null;

try {
    aFile = new RandomAccessFile("E:\\test1.xml", "rw");
    FileChannel inChannel = aFile.getChannel();

    // create buffer with capacity of 48 bytes
    ByteBuffer buf = ByteBuffer.allocate(48);

    int bytesRead = inChannel.read(buf);// read into buffer.
    while (bytesRead != -1) {
        System.out.println("Read " + bytesRead);
        buf.flip();// make buffer ready for read

        while(buf.hasRemaining()){
            System.out.print((char) buf.get());// read 1 byte at a time
        }

        buf.clear();// make buffer ready for writing
        bytesRead = inChannel.read(buf);
    }
} catch (FileNotFoundException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
} catch (IOException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
} finally {
    if (aFile != null) {
        try {
            aFile.close();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } 
    }
}

注意 buf.flip() 的調用,首先讀取數據到Buffer,然後反轉Buffer,接着再從Buffer中讀取數據。下一節會深入講解Buffer的更多細節。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章