您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關java8中NIO緩沖區Buffer數據存儲的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
ByteBuffer,CharBuffer,ShortBuffer,IntBuffer,LongBuffer,FloatBuffer,
DoubleBuffer.
1、緩沖區在java nio中負責數據的存儲。緩沖區就是數組。用于存儲不同數據類型的數據。根據數據類型不同(boolean除外),提供了相應類型的緩沖區。
ByteBuffer,CharBuffer,ShortBuffer,IntBuffer,LongBuffer,FloatBuffer,
DoubleBuffer.
上述緩沖區的管理方式幾乎一致,通過allocate()獲取緩沖區。
//分配一個指定大小的緩沖區ByteBuffer byteBuffer = ByteBuffer.allocate(1024);
2、緩沖區中的四個核心屬性:
capacity:容量,表示緩沖區中最大存儲數據的容量。一旦聲明不能改變。
3、limit:界限,表示緩沖區中可以操作數據的大小。(limit后所得數據不能進行讀寫)。
4、position:位置,表示緩沖區中正在操作數據的位置。
position<=limit<=capacity
5、ByteBuffer的基本使用。
緩沖區存取數據的兩個核心方法:
put():存入數據到緩沖區
//分配一個指定大小的緩沖區 ByteBuffer byteBuffer = ByteBuffer.allocate(1024); System.out.println(byteBuffer.position()); System.out.println(byteBuffer.limit());; System.out.println(byteBuffer.capacity()); //利用put方法存入數據到緩沖區中 String str = "abcde"; byteBuffer.put(str.getBytes());
6、ByteBuffer的基本使用。
緩沖區存取數據的兩個核心方法:
get():獲取緩沖區的數據
//4、利用get()讀取緩沖區的數據 byte[] dst = new byte[byteBuffer.limit()]; byteBuffer.get(dst); System.out.println(new String(dst,0,dst.length));
7、調用flip()讀數據模式之后
//3、切換成讀取數據模式byteBuffer.flip();
8、調用flip()操作之后:
9、rewind()方法:可重復讀:
byteBuffer.rewind(); System.out.println("----------rewind()-------------"); System.out.println(byteBuffer.position()); System.out.println(byteBuffer.limit());; System.out.println(byteBuffer.capacity());
關于“java8中NIO緩沖區Buffer數據存儲的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。