关于Java中的NIO,网上很多资料,关于ByteBuffer类也有很多内容,这里要说的是clear、flip、rewind三个方法的区别和对应缓冲区的状态。
ByteBuffer类没有构造方法,只能通过ByteBuffer.allocate(int)来分配一个新的字节缓冲区
下面我用图片展示不同状态下缓冲区,图中管道即操作缓冲区的IO流
这里需要明白以下几个术语的含义:
缓冲区容量:capacity
限制:limit
位置:position
标记:mark
初始化和clear方法执行后的缓冲区状态,如下:
clear方法作用是清空缓冲区,设置位置为0,限制=容量,并取消标记,其源码如下:
准备读取或读取中的缓冲区状态,如下:
flip方法执行后的缓冲区状态,如下:
flip方法设置位置为0,限制=位置,并取消标记,其源码如下:
rewind方法执行后的缓冲区状态,如下:
rewind方法设置位置为0,限制不变,并取消标记,其源码如下:
ByteBuffer类没有构造方法,只能通过ByteBuffer.allocate(int)来分配一个新的字节缓冲区
下面我用图片展示不同状态下缓冲区,图中管道即操作缓冲区的IO流
这里需要明白以下几个术语的含义:
缓冲区容量:capacity
限制:limit
位置:position
标记:mark
初始化和clear方法执行后的缓冲区状态,如下:

clear方法作用是清空缓冲区,设置位置为0,限制=容量,并取消标记,其源码如下:
- public final Buffer clear() {
- position = 0; //设置为0
- limit = capacity; //极限和容量相同
- mark = -1; //取消标记
- return this;
- }
准备读取或读取中的缓冲区状态,如下:

flip方法执行后的缓冲区状态,如下:

flip方法设置位置为0,限制=位置,并取消标记,其源码如下:
- public final Buffer flip() {
- limit = position;
- position = 0;
- mark = -1;
- return this;
- }
rewind方法执行后的缓冲区状态,如下:

rewind方法设置位置为0,限制不变,并取消标记,其源码如下:
- public final Buffer flip() {
- limit = position;
- position = 0;
- mark = -1;
- return this;
- }