Java NIO緩衝區ByteBufferjava
抽象類Buffer的接口數組
capacity:做爲一個內存塊,Buffer有一個固定的大小值,也叫「capacity」。你只能往裏寫capacity個byte、long,char等類型。一旦Buffer滿了,須要將其清空(經過讀數據或者清除數據)才能繼續寫數據往裏寫數據。ui
position:當你寫數據到Buffer中時,position表示當前的位置。初始的position值爲0.當一個byte、long等數據寫到Buffer後, position會向前移動到下一個可插入數據的Buffer單元。position最大可爲capacity – 1。spa
當讀取數據時,也是從某個特定位置讀。當將Buffer從寫模式切換到讀模式,position會被重置爲0。當從Buffer的position處讀取數據時,position向前移動到下一個可讀的位置。.net
limit:在寫模式下,Buffer的limit表示你最多能往Buffer裏寫多少數據。 寫模式下,limit等於Buffer的capacity。code
當切換Buffer到讀模式時, limit表示你最多能讀到多少數據。所以,當切換Buffer到讀模式時,limit會被設置成寫模式下的position值。換句話說,你能讀到以前寫入的全部數據(limit被設置成已寫數據的數量,這個值在寫模式下就是position)。blog
上代碼和運行結果:
接口
@Test public void test090() { ByteBuffer buffer = ByteBuffer.allocate(199); String msg1 = "asdfghjkl"; String msg2 = "qwertyuiop"; String msg3 = "zxcvbnm"; buffer.put(msg1.getBytes()); buffer.put(msg2.getBytes()); buffer.put(msg3.getBytes(), 3, 2); System.out.println("length=" + buffer.array().length); System.out.println("capacity=" + buffer.capacity()); System.out.println("limit=" + buffer.limit()); System.out.println("position=" + buffer.position()); System.out.println("flip after..."); buffer.flip(); System.out.println("length=" + buffer.array().length); System.out.println("capacity=" + buffer.capacity()); System.out.println("limit=" + buffer.limit()); System.out.println("position=" + buffer.position()); int limit = buffer.limit(); byte[] dest = new byte[limit]; buffer.get(dest, 0, limit); System.out.println("the string is " + new String(dest)); }
運行結果:ip
length=199內存
capacity=199
limit=199
position=21
flip after...
length=199
capacity=199
limit=21
position=0
the string is asdfghjklqwertyuiopvb
Process finished with exit code 0
和ByteArrayOutputStream同樣,也能夠用來合併字節數組
見:http://my.oschina.net/xinxingegeya/blog/272509
===================END===================