• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            逛奔的蝸牛

            我不聰明,但我會很努力

               ::  :: 新隨筆 ::  ::  :: 管理 ::
            From: http://hhyyllgg.iteye.com/blog/1921386
            Java NIO 由以下幾個核心部分組成: 
            • Channels
            • Buffers
            • Selectors

            雖然Java NIO 中除此之外還有很多類和組件,但在我看來,Channel,Buffer 和 Selector 構成了核心的API。 
            Buffers 緩沖區,以及緩沖區如何工作,是所有 I/O 的基礎。所謂“輸入/輸出”講的無非就是把數據移 進或移出緩沖區。 

            概念:實際上緩沖區就是一個包含在對象里的基本數據元素數組 
            屬性:所有的緩沖區都具有四個屬性來提供關于其所包含的數據元素的信息。它們是: 
            • 容量(Capacity) 緩沖區能夠容納的數據元素的最大數量。這一容量在緩沖區創建時被設定,并且永遠不能被改變。
            • 上界(Limit) 緩沖區的第一個不能被讀或寫的元素。或者說,緩沖區中現存元素的計數。
            • 位置(Position) 下一個要被讀或寫的元素的索引。位置會自動由相應的get( )和put( )函數更新。
            • 標記(Mark) 一個備忘位置。調用mark( )來設定mark = postion。調用reset( )設定position = mark。標記在設定前是未定義的(undefined)。
            看下圖 新創建一個ByteBuffer 

             

            我們通過 ByteBuffer.allocate(11) 方法創建一個 10 個 byte 的數組緩沖區,初始狀態如上圖所示,position 的位置為 0,capacity 和 limit 默認都是數組長度。當我們寫入 5 個字節時位置變化如下圖所示: 

             


            這時如果我們想在不丟失位置的情況下進行一些修改,比如說將hello更改為MelloW 
            可以這樣實現 
            buffer.put(0,(byte)'M').put((byte)'w'); 
            修改后的Buffer圖像如下圖 


             

            如果我們想將緩沖區的 5 個字節數據寫入 Channel 通信信道,我們需要調用 byteBuffer.flip() 方法,數組的狀態又發生如下變化 

             


            還有一個方法 rewind (),會重置position的位置為0 但不改變limit的位置,可以使用rewind()后退,重讀已經被翻轉的緩沖區中的數據。 


            • 一旦讀完Buffer中的數據,需要讓Buffer準備好再次被寫入。可以通過clear()或compact()方法來完成。
            • 如果調用的是clear()方法,position將被設回0,limit被設置成 capacity的值。換句話說,Buffer 被清空了。但這個時候Buffer中的數據并未清除,只是這些標記告訴我們可以從哪里開始往Buffer里寫數據。

            看下面代碼
            Java代碼  收藏代碼
            1. public static void main(String[] argv) throws Exception {  
            2.         CharBuffer buffer = CharBuffer.allocate(20);  
            3.         System.out.println("初始化時候:position="+buffer.position()+" limit="+buffer.limit());  
            4.         fillBuffer(buffer,"hello");  
            5.         System.out.println("填入hello以后:position="+buffer.position()+" limit="+buffer.limit());  
            6.         buffer.put(0,'M').put('w');  
            7.         System.out.println("修改成Mellow后:position="+buffer.position()+" limit="+buffer.limit());  
            8.         buffer.flip();  
            9.         System.out.println("翻轉后:position="+buffer.position()+" limit="+buffer.limit());  
            10.         buffer.clear();  
            11.         System.out.println("clear后:position="+buffer.position()+" limit="+buffer.limit());  
            12.         buffer.position(0);  
            13.         while (buffer.hasRemaining()) {  
            14.             System.out.println(buffer.get());  
            15.         }  
            16.     }private static void fillBuffer(CharBuffer buffer) {  
            17.         String string = "MY TEST BUFFER";  
            18.         for (int i = 0; i < string.length(); i++) {  
            19.             buffer.put(string.charAt(i));  
            20.         }  
            21.     }  
            22.   
            23. 結果:  
            24. 初始化時候:position=0 limit=20  
            25. 填入hello以后:position=5 limit=20  
            26. 修改成Mellow后:position=6 limit=20  
            27. 翻轉后:position=0 limit=6  
            28. clear后:position=0 limit=20  
            29. M  
            30. e  
            31. l  
            32. l  
            33. o  
            34. w  

            從上面例子可以看出clear后實際上buffer中數據還是存在的 
            如果Buffer中有一些未讀的數據,調用clear()方法,數據將“被遺忘”,意味著不再有任何標記會告訴你哪些數據被讀過,哪些還沒有。 
            如果Buffer中仍有未讀的數據,且后續還需要這些數據,但是此時想要先先寫些數據,那么使用compact()方法。 
            看下面代碼: 
            Java代碼  收藏代碼
            1. public static void compactTest(){  
            2.         CharBuffer buffer = CharBuffer.allocate(11);  
            3.         fillBuffer(buffer,"hello world");  
            4.         buffer.position(6);  
            5.         buffer.compact();  
            6.         buffer.put("j");  
            7.         buffer.put("a");  
            8.         buffer.put("v");  
            9.         buffer.put("a");  
            10.         buffer.flip();  
            11.         while (buffer.hasRemaining()) {  
            12.             System.out.print(buffer.get());  
            13.         }  
            14.     }  
            15. 打印結果為worldjava  

            compact()方法將所有未讀的數據拷貝到Buffer起始處。然后將position設到最后一個未讀元素正后面。limit屬性依然像clear()方法一樣,設置成capacity?,F在Buffer準備好寫數據了,但是不會覆蓋未讀的數據。 
            其它還有mark()與reset() equals()等方法 就不一一介紹了。 
            @import url(http://www.shnenglu.com/CuteSoft_Client/CuteEditor/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/css/cuteeditor.css);
            posted on 2013-08-07 22:04 逛奔的蝸牛 閱讀(767) 評論(0)  編輯 收藏 引用 所屬分類: Java
            亚洲欧洲久久久精品| 亚洲v国产v天堂a无码久久| 久久精品国产免费观看 | 久久国产热精品波多野结衣AV| 久久精品国产黑森林| 一本久道久久综合狠狠躁AV| 亚洲伊人久久成综合人影院 | 香蕉久久一区二区不卡无毒影院| 国产精品欧美久久久久无广告| 国产精品激情综合久久| 久久天天躁狠狠躁夜夜avapp| 久久精品aⅴ无码中文字字幕不卡 久久精品aⅴ无码中文字字幕重口 | 久久99国产一区二区三区| 一本久久精品一区二区| 九九99精品久久久久久| 亚洲乱码日产精品a级毛片久久| 久久亚洲精品成人av无码网站 | 国产精品无码久久综合网| 久久精品视频一| 久久亚洲高清观看| 久久精品国产2020| 精品国产综合区久久久久久 | 精品国产综合区久久久久久 | 久久免费国产精品一区二区| 狠狠色丁香久久婷婷综合图片| 久久九九亚洲精品| 久久99精品国产麻豆| 亚洲伊人久久大香线蕉综合图片| 国产午夜精品久久久久九九| 久久精品人人做人人爽97| 久久久久久久女国产乱让韩| 色综合合久久天天给综看| 久久精品视频91| 成人国内精品久久久久影院VR| 国产亚洲欧美成人久久片| 日韩精品久久无码人妻中文字幕| 久久无码高潮喷水| 国产亚洲精品久久久久秋霞| 国产成人无码精品久久久性色| 久久91精品国产91| 久久精品国产AV一区二区三区 |