• <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://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
            亚洲精品无码久久不卡| 国产精品久久久天天影视香蕉 | 国产精品久久久久蜜芽| 7777精品久久久大香线蕉| 国产精品久久成人影院| 2021国内久久精品| 国产一区二区精品久久凹凸| 一本色道久久88综合日韩精品| 久久精品国产亚洲精品2020| 久久免费视频6| 国产午夜免费高清久久影院| 日本亚洲色大成网站WWW久久| 久久香综合精品久久伊人| 久久久精品日本一区二区三区| 国内精品久久久久久99蜜桃| 亚洲AV伊人久久青青草原| 久久综合国产乱子伦精品免费| 欧美午夜A∨大片久久 | av色综合久久天堂av色综合在| 国产精品无码久久久久| 久久久国产乱子伦精品作者| 思思久久好好热精品国产| 亚洲国产精品婷婷久久| 久久久久免费精品国产| 久久99国内精品自在现线| 99久久无色码中文字幕人妻| 欧美无乱码久久久免费午夜一区二区三区中文字幕| 久久久久成人精品无码中文字幕| 精品久久久久久久国产潘金莲| 精品国产青草久久久久福利| 51久久夜色精品国产| 国产亚洲成人久久| 久久久无码精品午夜| 久久久久亚洲AV无码专区桃色| 久久成人18免费网站| 久久综合五月丁香久久激情| 久久久WWW成人| 99精品国产免费久久久久久下载| 亚洲欧美一区二区三区久久| 大香伊人久久精品一区二区| 色欲久久久天天天综合网精品|