• <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) 緩沖區的第一個不能被讀或寫的元素?;蛘哒f,緩沖區中現存元素的計數。
            • 位置(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://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 逛奔的蝸牛 閱讀(766) 評論(0)  編輯 收藏 引用 所屬分類: Java
            97久久精品无码一区二区天美| 一本综合久久国产二区| 99热都是精品久久久久久| 亚洲欧洲日产国码无码久久99| 久久精品国产一区二区电影| 中文字幕久久欲求不满| 中文字幕亚洲综合久久2| 2021久久国自产拍精品| 亚洲欧美精品伊人久久| 成人a毛片久久免费播放| 久久人人爽人人爽AV片| 香蕉久久夜色精品国产尤物| 模特私拍国产精品久久| 亚洲精品tv久久久久久久久| 少妇内射兰兰久久| 精品999久久久久久中文字幕| 久久久久久久99精品免费观看| 国产成人精品久久综合| 亚洲国产成人精品无码久久久久久综合 | 久久久一本精品99久久精品88| 久久亚洲精品无码VA大香大香| 久久人做人爽一区二区三区| 人妻精品久久无码专区精东影业| 国产精品久久久久久久久鸭 | 国产精品久久久久久久人人看| 久久精品国产精品亚洲精品 | 精品国产VA久久久久久久冰 | 国内精品免费久久影院| 青青草国产97免久久费观看| 亚洲AV无码久久精品狠狠爱浪潮| 久久综合综合久久97色| 伊人色综合久久天天人守人婷| 国产三级久久久精品麻豆三级| 91久久香蕉国产熟女线看| 亚洲人成精品久久久久| 国产三级精品久久| 久久99国产乱子伦精品免费| 久久国产一片免费观看| 久久免费视频观看| 久久热这里只有精品在线观看| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区 |