本篇文章給大家分享的是有關如何分析Java NIO中的Buffer對象,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
我們提供的服務有:成都網(wǎng)站制作、成都網(wǎng)站建設、外貿營銷網(wǎng)站建設、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認證、商南ssl等。為成百上千企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務,是有科學管理、有技術的商南網(wǎng)站制作公司
在緩沖區(qū)中,最重要的屬性有下面三個,它們一起合作完成對緩沖區(qū)內部狀態(tài)的變化跟蹤:
position:指定了下一個將要被寫入或者讀取的元素索引,它的值由get()/put()方法自動更新,在新創(chuàng)建一個Buffer對象時,position被初始化為0。
limit:指定還有多少數(shù)據(jù)需要取出(在從緩沖區(qū)寫入通道時),或者還有多少空間可以放入數(shù)據(jù)(在從通道讀入緩沖區(qū)時)。
capacity:指定了可以存儲在緩沖區(qū)中的最大數(shù)據(jù)容量,實際上,它指定了底層數(shù)組的大小,或者至少是指定了準許我們使用的底層數(shù)組的容量。
以上四個屬性值之間有一些相對大小的關系:0 <= position <= limit <= capacity。如果我們創(chuàng)建一個新的容量大小為10的ByteBuffer對象,在初始化的時候,position設置為0,limit和 capacity被設置為10,在以后使用ByteBuffer對象過程中,capacity的值不會再發(fā)生變化,而其它兩個個將會隨著使用而變化。四個屬性值分別如圖所示:
現(xiàn)在我們可以從通道中讀取一些數(shù)據(jù)到緩沖區(qū)中,注意從通道讀取數(shù)據(jù),相當于往緩沖區(qū)中寫入數(shù)據(jù)。如果讀取4個自己的數(shù)據(jù),則此時position的值為4,即下一個將要被寫入的字節(jié)索引為4,而limit仍然是10。
下一步把讀取的數(shù)據(jù)寫入到輸出通道中,相當于從緩沖區(qū)中讀取數(shù)據(jù),在此之前,必須調用flip()方法,該方法將會完成兩件事情:
1. 把limit設置為當前的position值
2. 把position設置為0
由于position被設置為0,所以可以保證在下一步輸出時讀取到的是緩沖區(qū)中的第一個字節(jié),而limit被設置為當前的position,可以保證讀取的數(shù)據(jù)正好是之前寫入到緩沖區(qū)中的數(shù)據(jù),如下圖所示:
現(xiàn)在調用get()方法從緩沖區(qū)中讀取數(shù)據(jù)寫入到輸出通道,這會導致position的增加而limit保持不變,但position不會超過limit的值,所以在讀取我們之前寫入到緩沖區(qū)中的4個自己之后,position和limit的值都為4。
在從緩沖區(qū)中讀取數(shù)據(jù)完畢后,limit的值仍然保持在我們調用flip()方法時的值,調用clear()方法能夠把所有的狀態(tài)變化設置為初始化時的值,
最后我們用一段代碼來驗證這個過程,如下所示:
[java] view plain copy
print?
import java.io.*;
import java.nio.*;
import java.nio.channels.*;
public class Program {
public static void main(String args[]) throws Exception {
FileInputStream fin = new FileInputStream("d:\\test.txt");
FileChannel fc = fin.getChannel();
ByteBuffer buffer = ByteBuffer.allocate(10);
output("初始化", buffer);
fc.read(buffer);
output("調用read()", buffer);
buffer.flip();
output("調用flip()", buffer);
while (buffer.remaining() > 0) {
byte b = buffer.get();
// System.out.print(((char)b));
}
output("調用get()", buffer);
buffer.clear();
output("調用clear()", buffer);
fin.close();
}
public static void output(String step, Buffer buffer) {
System.out.println(step + " : ");
System.out.print("capacity: " + buffer.capacity() + ", ");
System.out.print("position: " + buffer.position() + ", ");
System.out.println("limit: " + buffer.limit());
System.out.println();
}
}
完成的輸出結果與我們上面演示的過程一致。
以上就是如何分析Java NIO中的Buffer對象,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。