在NIO中,數據的讀寫操作始終是與緩沖區相關聯的.讀取時信道(SocketChannel)將數據讀入緩沖區,寫入時首先要將發送的數據按順序填入緩沖區.緩沖區是定長的,基本上它只是一個列表,它的所有元素都是基本數據類型.ByteBuffer是最常用的緩沖區,它提供了讀寫其他數據類型的方法,且信道的讀寫方法只接收ByteBuffer.因此ByteBuffer的用法是有必要牢固掌握的.
1.創建ByteBuffer
1.1 使用allocate()靜態方法
ByteBuffer
buffer=ByteBuffer.allocate(256);
以上方法將創建一個容量為256字節的ByteBuffer,如果發現創建的緩沖區容量太小,唯一的選擇就是重新創建一個大小合適的緩沖區.
1.2 通過包裝一個已有的數組來創建
如下,通過包裝的方法創建的緩沖區保留了被包裝數組內保存的數據.
ByteBuffer
buffer=ByteBuffer.wrap(byteArray);
如果要將一個字符串存入ByteBuffer,可以如下操作:
String sendString="你好,服務器. ";
ByteBuffer
sendBuffer=ByteBuffer.wrap(sendString.getBytes("UTF-16"));
2.回繞緩沖區
buffer.flip();
這個方法用來將緩沖區準備為數據傳出狀態,執行以上方法后,輸出通道會從數據的開頭而不是末尾開始.回繞保持緩沖區中的數據不變,只是準備寫入而不是讀取.
3.清除緩沖區
buffer.clear();
這個方法實際上也不會改變緩沖區的數據,而只是簡單的重置了緩沖區的主要索引值.不必為了每次讀寫都創建新的緩沖區,那樣做會降低性能.相反,要重用現在的緩沖區,在再次讀取之前要清除緩沖區.
4.從套接字通道(信道)讀取數據
int bytesReaded=socketChannel.read(buffer);
執行以上方法后,通道會從socket讀取的數據填充此緩沖區,它返回成功讀取并存儲在緩沖區的字節數.在默認情況下,這至少會讀取一個字節,或者返回-1指示數據結束.
5.向套接字通道(信道)寫入數據
socketChannel.write(buffer);
此方法以一個ByteBuffer為參數,試圖將該緩沖區中剩余的字節寫入信道.