<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    yeshucheng
    追逐自己,追逐方向,心隨悟所動
    posts - 24,comments - 24,trackbacks - 0
     

    數據對于輸入和輸出的操作耗時是非常嚴重的問題,如果把這個問題放入到網絡上去看待更甚是值得注意的一個問題了。假如結合基礎的OS知識我們也知道如果要減少這種I/O操作的耗時或者也可以說提升這種效率的話,最大的可能就是減少物理讀寫的次數,而且盡可能做到主存數據的重讀性(操作系統也在加強說明更多減少抖動現象的產生)。

    java.nio包中我們可以直接來操作相對應的API了。可以讓java更加方便的直接控制和運用緩沖區。緩沖區有幾個需要了解的特定概念需要詳盡來解釋,才能更好的知道我們下面一些列需要針對的問題實質。

    屬性

    容量(capacity):顧名思義就是表示緩沖區中可以保存多少數據;

    極限(limit):緩沖區中的當前數據終結點。不過它是可以動態改變的,這樣做的好處也是充分利用重用性;

    位置(position):這個也好理解,其實就是指明下一個需要讀寫數據的位置。

    上面上個關系還可以具體用圖示的方式來表達整體概念,如下圖所示:


    在極限的時候就說到可以修改它,所以對于它的操作由以下方法:

    l         clear():首先把極限設置為容量,再者就是需要把位置設置為0

    l         flip():把極限設置為位置區,再者就是需要把位置設置為0

    l         rewind():不改變極限,不過還是需要把位置設置為0

    最為最基礎的緩沖區ByteBuffer,它存放的數據單元是字節。首先要強調的是ByteBuffer沒有提供公開的構造方法,只是提供了兩個靜態的工廠方法。

    l         allocate(int capacity):返回一個ByteBuffer對象,參數表示緩沖區容量大小。

    l         allocateDirect (int capacity):返回一個ByteBuffer對象,參數也是一樣表示緩沖區容量大小。

    在這里需要注意的是在使用兩者的時候需要特別小心,allocateDirect和當前操作系統聯系的非常緊密,它牽涉到使用native method的方法,大家知道一旦本地方法就是需要考慮調用dll(動態鏈接庫)這個時候基本也就失去了JAVA語言的特性,言外之意對于耗資源非常大。所以如果考慮到當前使用的緩存區比較龐大而且是一個長期駐留使用的,這個時候可以考慮使用它。

    posted on 2009-02-13 20:56 葉澍成 閱讀(244) 評論(0)  編輯  收藏 所屬分類: java基礎NIO學習
    主站蜘蛛池模板: 亚洲看片无码在线视频| 亚洲欧洲免费视频| 亚洲人成色在线观看| 日本三级2019在线观看免费| 亚洲美女一区二区三区| 8888四色奇米在线观看免费看| 亚洲毛片在线观看| 免费大片黄在线观看yw| 一本色道久久88亚洲精品综合| 成年人免费观看视频网站| 亚洲国产精品嫩草影院 | 丁香花免费完整高清观看| 亚洲免费人成视频观看| 性感美女视频在线观看免费精品| 亚洲日韩AV一区二区三区中文 | 97视频免费观看2区| 亚洲成a人片77777群色| 成在人线AV无码免费| 黄色大片免费网站| 亚洲精品无码久久久久去q| 99精品热线在线观看免费视频| 亚洲一区二区三区免费视频| 最近最新的免费中文字幕| 日本一区二区三区在线视频观看免费| 亚洲欧洲中文日韩久久AV乱码| 久久精品国产这里是免费| 亚洲AV色吊丝无码| 亚洲男人的天堂一区二区| 一级毛片免费播放| 日韩亚洲综合精品国产| 国产亚洲精品精华液| 毛片在线免费视频| 色www永久免费网站| 亚洲最大成人网色香蕉| 亚洲欧洲久久久精品| 亚洲最大免费视频网| 国产成人亚洲精品无码AV大片| 国产AV无码专区亚洲A∨毛片| 在线观看免费人成视频色9| 一个人看www免费高清字幕| 亚洲精品在线播放|