• <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://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 逛奔的蝸牛 閱讀(767) 評論(0)  編輯 收藏 引用 所屬分類: Java
            国产亚洲精品自在久久| 久久伊人影视| 国产亚洲精品自在久久| 国产麻豆精品久久一二三| 国产一级持黄大片99久久| 久久99热这里只有精品国产| 天天影视色香欲综合久久| 免费无码国产欧美久久18| 97r久久精品国产99国产精| 国产一区二区精品久久凹凸| 精品久久久无码21p发布| 青青草原1769久久免费播放| 久久亚洲精品国产精品婷婷| 国产韩国精品一区二区三区久久| 亚洲国产天堂久久久久久 | 国产精品无码久久综合| 欧美激情精品久久久久| 久久久无码精品亚洲日韩京东传媒 | 国内高清久久久久久| 伊人久久大香线蕉精品| 国内精品伊人久久久久777| 国产亚洲精午夜久久久久久| a高清免费毛片久久| 午夜精品久久久久久中宇| 久久综合九色综合欧美就去吻| 久久精品无码专区免费东京热| 久久大香萑太香蕉av| 少妇久久久久久被弄到高潮| 精品久久久久久无码免费| 久久精品www| 国产高清美女一级a毛片久久w| 久久久久久人妻无码| 综合网日日天干夜夜久久| 伊人久久大香线蕉av不变影院| 久久只有这精品99| 久久九九久精品国产免费直播| 亚洲精品国产自在久久| 久久亚洲日韩看片无码| 99精品国产综合久久久久五月天| 久久久久久亚洲精品影院| 狠狠色丁香久久婷婷综合_中 |