java:BIO, NIO
生活随笔
收集整理的這篇文章主要介紹了
java:BIO, NIO
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
?
BIO面向流.? ? ? ? ?阻塞式
?NIO面向緩沖區(qū). 非阻塞式
?channnel負(fù)責(zé)傳輸,? ?buffer負(fù)責(zé)存儲(chǔ).
?
?
import java.nio.ByteBuffer;public class TestBuffer {public static void main(String[] args) {TestBuffer.test2();}public static void test2() {String str = "abcde";ByteBuffer buf = ByteBuffer.allocate(1024);buf.put(str.getBytes());buf.flip();byte[] dst = new byte[buf.limit()];buf.get(dst,0,2);System.out.println(new String(dst,0,2));System.out.println(buf.position());buf.mark(); // 標(biāo)記buf.get(dst,2,2);System.out.println(new String(dst,2,2));buf.reset(); // 恢復(fù)到mark的位置System.out.println(buf.position());// 判斷緩沖區(qū)中是否有剩余數(shù)據(jù)if(buf.hasRemaining()){// 獲取緩沖區(qū)中可以操作的數(shù)量System.out.println(buf.remaining());}}public static void test1(){String str = "abcde";//1. 分配一個(gè)指定大小的緩沖區(qū)ByteBuffer buf = ByteBuffer.allocate(1024);System.out.println(buf.capacity());System.out.println(buf.limit());System.out.println(buf.position());// 2. 利用put()存入數(shù)據(jù)到緩沖區(qū)buf.put(str.getBytes());// 3. 切換到讀取數(shù)據(jù)模式buf.flip();// 4. 利用get()讀取緩沖區(qū)數(shù)據(jù)byte[] dst = new byte[buf.limit()];buf.get(dst);System.out.println(new String(dst,0,dst.length));//5. rewind():可重復(fù)讀buf.rewind();// 6. clear清空緩沖區(qū)。但緩沖區(qū)中的數(shù)據(jù)依然存在。buf.clear();System.out.println(buf.capacity());System.out.println(buf.limit());System.out.println(buf.position());} }?
直接緩沖區(qū)域,非直接緩沖區(qū)
?直接緩沖區(qū)域:通過allocate()方法分配緩沖區(qū),將緩沖區(qū)建立再jvm的內(nèi)存中。
?非直接緩沖區(qū):通過allocateDirect()方法分配直接緩沖區(qū),將緩沖區(qū)建立在物理內(nèi)存中??梢蕴岣咝?。
?
?
?通道(channel)
? channel本身不能直接訪問數(shù)據(jù),channel只能與buffer進(jìn)行交互。
??
總結(jié)
以上是生活随笔為你收集整理的java:BIO, NIO的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java:juc一
- 下一篇: 常考数据结构与算法:反转链表