Java NIO 入门学习(通道和缓冲区)

本文详细解析了Java NIO的核心组件Channel和Buffer,包括它们在文件和网络I/O操作中的作用,以及如何通过FileChannel和SocketChannel进行高效的数据传输。重点介绍了Buffer的多种实现方式和在缓冲区上的数据操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

对于 NIO 来说,Channel(通道) 和 Buffer(缓冲区) 这两个东西是不得不提的,因为它们是 NIO 的核心对象,几乎每一个 I/O 操作都要它们。

通道是对原 I/O 流的模拟,但有不同的是它是双向的,不再像流那样分 InputStream 和 OutputStream,通道的双向性更好的反映了底层操作系统的真识情况。也不能像原 I/O 那样可以直接往流里写或读数据,在通道了传输数据必须经由缓冲区。有点类似原 I/O 流通过过滤器流 BufferedInputStream 和 BufferedOutputStream 来读写数据。

FileInputStream/FileOutputStream/RandomAccessFile/DatagramSocket/ServerSocket/Socket 的 getChannel() 方法可以获得相应类型的 Channel,Channel 的类型有 FileChannel/SocketChannel/SelectableChannel/DatagramChannel/ServerSocketChannel 等。

在通道上的读写都会关联上缓冲区,如 FileChannel.read(ByteBuffer dst)、FileChannel.write(ByteBuffer src);对文件的锁也是在通道上的操作,如 FileChannel.lock()、FileChannel.tryLock()。

Buffer 接口的实现类有 ByteBuffer/MappedByteBuffer/CharBuffer/DoubleBuffer/FloadBuffer /IntBuffer/LongBuffer/ShortBuffer,用得多的还就是 ByteBuffer。在 Buffer 上则是些存取数据和数据定位的操作。

下面是 NIO 和原 IO 的一些概念对比:

其他的如 SocketChannel 网络通道还未述及,理解了 NIO 通道和缓冲区的概念之后,我们就可以使用 NIO 来对文件进行读写操作了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值