Buffer管理著給定數(shù)目的數(shù)據(jù)元素。但是在大多數(shù)情況下,我們只關(guān)心其中的一部分數(shù)據(jù)。就像是,當我們想要向池子里倒水時,水盆里的水,只盛了一半。但我們需要追蹤一些信息,buffer中已經(jīng)有的數(shù)據(jù),下一個處理哪個數(shù)據(jù)?position屬性負責處理這個信息。當處理put(向buffer中寫入數(shù)據(jù))或者get方法(從buffer中獲取數(shù)據(jù))的時候,position就會更新。
盡管在JAVA NIO BUFFER(一)中,列表中沒有put和get方法。但是每個Buffer都包含這兩個方法,因為每個buffer的實現(xiàn)不同,需要處理不同的數(shù)據(jù)類型,沒法被聲明為抽象方法(nio在jdk1.4被引入,泛型是1.5)。我們用ByteBuffer作為例子,來看這兩個方法的聲明
public abstract class ByteBuffer extends Buffer implements Comparable {
//列出了一部分api
public abstract byte get();
public abstract byte get(int index);
public abstract ByteBuffer put(byte b);
public abstract ByteBuffer put(int index, byte b);
}
如果不指定具體的位置,put和get就會操作在現(xiàn)有的position屬性上,并將position加1。如果超出了capacity。如果是讀操作就會拋出BufferOverflowException,寫操作就會BufferUnderflowException.如果是任意操作,也會拋出一個IndexOutOfBoundsException.
讓我們試著對ByteBuffer中寫入數(shù)據(jù),如果執(zhí)行下面的命令,JAVA NIO BUFFER(一)中的概念圖,就會變成如下的樣子。
buffer.put((byte)'H').put((byte)'e').put((byte)'l').put((byte)'l').put((byte)'o');

猜一猜,如果執(zhí)行這個命令
buffer.put(0,(byte)'M').put((byte)'w');
會變成什么樣子?

會變成這樣!,第一個把0位置的H替換為M,然后緊接著的put操作查看到了position在5位置,把5位置寫入W,然后position自加變?yōu)?.