【Java】NIO中的Buffer、limit、position

2022-05-27  本文已影响0人  小北觅

通过本文可以获得如下知识:
① 图解NIO Buffer中的capacity、position、limit的含义。
② 一个Java demo程序演示三者的变化关系。
③ Buffer常用方法。

我们知道Java NIO 由以下三个核心部分组成:

在编写NIO程序时,我们对数据的实际操作都是通过Buffer来进行的,经常会用到java.nio.Buffer中的flip()方法。

本文会通过NIO程序实例来讲解flip方法以及limit、position、capacity三个成员变量。

一、Buffer

我们使用 Buffer 与 Channel 交互,数据从Channel读入Buffer,或从Buffer写入到Channel中。

缓冲区的本质是一个可以写入数据的内存区域,之后可以读取数据。 Buffer 对象包装了此内存区域,并提供了一组方法,可以更轻松地使用内存块。

1.1 Buffer的几个重要成员变量

以上三个属性值之间有一个相对大小的关系:0 <= position <= limit <= capacity。

下面我们用一个图例来解释一下这三个属性的关系及变化过程。

假设我们创建了一个容量为10的ByteBuffer对象,在初始化时,position会被设置为0,limit和capacity被设置为10。在之后使用ByteBuffer对象过程中,capacity的值不会再发生变化,而其它两个值会随着使用而变化。初始时三个属性的值如下图所示:

上一篇下一篇

猜你喜欢

热点阅读