您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“在NIO庫中什么是緩沖區(qū)與通道”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“在NIO庫中什么是緩沖區(qū)與通道”吧!
什么是緩沖區(qū)
Buffer是一個(gè)對象,它包含一些要寫入或者剛讀出的數(shù)據(jù)。在NIO中加入Buffer對象,體現(xiàn)了新庫與原I/O的一個(gè)重要區(qū)別。在面向流的I/O中,您將數(shù)據(jù)直接寫入或者將數(shù)據(jù)直接讀到Stream對象中。
在NIO庫中,所有數(shù)據(jù)都是用緩沖區(qū)處理的。在讀取數(shù)據(jù)時(shí),它是直接讀到緩沖區(qū)中的。在寫入數(shù)據(jù)時(shí),它是寫入到緩沖區(qū)中的。任何時(shí)候訪問NIO中的數(shù)據(jù),您都是將它放到緩沖區(qū)中。
緩沖區(qū)實(shí)質(zhì)上是一個(gè)數(shù)組。通常它是一個(gè)字節(jié)數(shù)組,但是也可以使用其他種類的數(shù)組。但是一個(gè)緩沖區(qū)不僅僅是一個(gè)數(shù)組。緩沖區(qū)提供了對數(shù)據(jù)的結(jié)構(gòu)化訪問,而且還可以跟蹤系統(tǒng)的讀/寫進(jìn)程。
緩沖區(qū)類型
最常用的緩沖區(qū)類型是ByteBuffer.一個(gè)ByteBuffer可以在其底層字節(jié)數(shù)組上進(jìn)行g(shù)et/set操作(即字節(jié)的獲取和設(shè)置)。
ByteBuffer不是NIO中唯一的緩沖區(qū)類型。事實(shí)上,對于每一種基本Java類型都有一種緩沖區(qū)類型:
ByteBufferCharBufferShortBufferIntBufferLongBufferFloatBufferDoubleBuffer每一個(gè)Buffer類都是Buffer接口的一個(gè)實(shí)例。除了ByteBuffer,每一個(gè)Buffer類都有完全一樣的操作,只是它們所處理的數(shù)據(jù)類型不一樣。因?yàn)榇蠖鄶?shù)標(biāo)準(zhǔn)I/O操作都使用ByteBuffer,所以它具有所有共享的緩沖區(qū)操作以及一些特有的操作。
現(xiàn)在您可以花一點(diǎn)時(shí)間運(yùn)行UseFloatBuffer.java,它包含了類型化的緩沖區(qū)的一個(gè)應(yīng)用例子。
什么是通道
Channel是一個(gè)對象,可以通過它讀取和寫入數(shù)據(jù)。拿NIO與原來的I/O做個(gè)比較,通道就像是流。
正如前面提到的,所有數(shù)據(jù)都通過Buffer對象來處理。您永遠(yuǎn)不會將字節(jié)直接寫入通道中,相反,您是將數(shù)據(jù)寫入包含一個(gè)或者多個(gè)字節(jié)的緩沖區(qū)。同樣,您不會直接從通道中讀取字節(jié),而是將數(shù)據(jù)從通道讀入緩沖區(qū),再從緩沖區(qū)獲取這個(gè)字節(jié)。
通道類型
通道與流的不同之處在于通道是雙向的。而流只是在一個(gè)方向上移動(一個(gè)流必須是InputStream或者OutputStream的子類),而通道可以用于讀、寫或者同時(shí)用于讀寫。
因?yàn)樗鼈兪请p向的,所以通道可以比流更好地反映底層操作系統(tǒng)的真實(shí)情況。特別是在UNIX模型中,底層操作系統(tǒng)通道是雙向的。
到此,相信大家對“在NIO庫中什么是緩沖區(qū)與通道”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。