• <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。現在Buffer準備好寫數據了,但是不會覆蓋未讀的數據。 
            其它還有mark()與reset() equals()等方法 就不一一介紹了。 
            @import url(http://m.shnenglu.com/CuteSoft_Client/CuteEditor/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/css/cuteeditor.css);
            posted on 2013-08-07 22:04 逛奔的蝸牛 閱讀(768) 評論(0)  編輯 收藏 引用 所屬分類: Java
            亚洲va久久久久| 97精品伊人久久久大香线蕉| 亚洲乱码日产精品a级毛片久久 | 久久亚洲色一区二区三区| 久久免费大片| 日本人妻丰满熟妇久久久久久| 久久精品夜夜夜夜夜久久| 91久久精品无码一区二区毛片| 亚洲欧美一级久久精品| 国产精品无码久久综合| 午夜视频久久久久一区| 99久久人妻无码精品系列| 色偷偷88欧美精品久久久| 九九精品99久久久香蕉| 狠狠色丁香婷婷久久综合五月| 国产精品久久99| 亚洲国产精品无码久久98| 国産精品久久久久久久| 狠狠狠色丁香婷婷综合久久五月| 亚洲精品综合久久| 婷婷久久综合九色综合九七| 国产精品美女久久久免费| 国产精品久久国产精麻豆99网站| 久久久精品国产免大香伊 | 精品久久久久久久久午夜福利| 久久综合视频网站| 久久se精品一区精品二区国产| 丰满少妇高潮惨叫久久久| 五月丁香综合激情六月久久| 精品综合久久久久久98| 午夜精品久久久久久影视riav| 久久精品女人天堂AV麻| 久久精品国产WWW456C0M| AAA级久久久精品无码区| 热99re久久国超精品首页| 国产精品青草久久久久婷婷| 色综合久久无码中文字幕| 日本欧美久久久久免费播放网| 伊人久久综合无码成人网| 99精品国产综合久久久久五月天| 亚洲午夜久久久久久久久久|