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