本篇內(nèi)容主要講解“在NIO庫中什么是緩沖區(qū)與通道”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學(xué)習(xí)“在NIO庫中什么是緩沖區(qū)與通道”吧!

什么是緩沖區(qū)
Buffer是一個對象,它包含一些要寫入或者剛讀出的數(shù)據(jù)。在NIO中加入Buffer對象,體現(xiàn)了新庫與原I/O的一個重要區(qū)別。在面向流的I/O中,您將數(shù)據(jù)直接寫入或者將數(shù)據(jù)直接讀到Stream對象中。
在NIO庫中,所有數(shù)據(jù)都是用緩沖區(qū)處理的。在讀取數(shù)據(jù)時,它是直接讀到緩沖區(qū)中的。在寫入數(shù)據(jù)時,它是寫入到緩沖區(qū)中的。任何時候訪問NIO中的數(shù)據(jù),您都是將它放到緩沖區(qū)中。
緩沖區(qū)實質(zhì)上是一個數(shù)組。通常它是一個字節(jié)數(shù)組,但是也可以使用其他種類的數(shù)組。但是一個緩沖區(qū)不僅僅是一個數(shù)組。緩沖區(qū)提供了對數(shù)據(jù)的結(jié)構(gòu)化訪問,而且還可以跟蹤系統(tǒng)的讀/寫進程。
緩沖區(qū)類型
最常用的緩沖區(qū)類型是ByteBuffer.一個ByteBuffer可以在其底層字節(jié)數(shù)組上進行g(shù)et/set操作(即字節(jié)的獲取和設(shè)置)。
ByteBuffer不是NIO中的緩沖區(qū)類型。事實上,對于每一種基本Java類型都有一種緩沖區(qū)類型:
ByteBufferCharBufferShortBufferIntBufferLongBufferFloatBufferDoubleBuffer每一個Buffer類都是Buffer接口的一個實例。除了ByteBuffer,每一個Buffer類都有完全一樣的操作,只是它們所處理的數(shù)據(jù)類型不一樣。因為大多數(shù)標(biāo)準(zhǔn)I/O操作都使用ByteBuffer,所以它具有所有共享的緩沖區(qū)操作以及一些特有的操作。
現(xiàn)在您可以花一點時間運行UseFloatBuffer.java,它包含了類型化的緩沖區(qū)的一個應(yīng)用例子。
什么是通道
Channel是一個對象,可以通過它讀取和寫入數(shù)據(jù)。拿NIO與原來的I/O做個比較,通道就像是流。
正如前面提到的,所有數(shù)據(jù)都通過Buffer對象來處理。您永遠不會將字節(jié)直接寫入通道中,相反,您是將數(shù)據(jù)寫入包含一個或者多個字節(jié)的緩沖區(qū)。同樣,您不會直接從通道中讀取字節(jié),而是將數(shù)據(jù)從通道讀入緩沖區(qū),再從緩沖區(qū)獲取這個字節(jié)。
通道類型
通道與流的不同之處在于通道是雙向的。而流只是在一個方向上移動(一個流必須是InputStream或者OutputStream的子類),而通道可以用于讀、寫或者同時用于讀寫。
因為它們是雙向的,所以通道可以比流更好地反映底層操作系統(tǒng)的真實情況。特別是在UNIX模型中,底層操作系統(tǒng)通道是雙向的。
到此,相信大家對“在NIO庫中什么是緩沖區(qū)與通道”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)建站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
分享題目:在NIO庫中什么是緩沖區(qū)與通道-創(chuàng)新互聯(lián)
本文網(wǎng)址:http://www.yijiale78.com/article2/dodiic.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計、ChatGPT、云服務(wù)器、微信公眾號、定制網(wǎng)站、營銷型網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容