java.nio.Buffer 中的 flip()方法
在Java NIO编程中,对缓冲区操作常常需要使用 java.nio.Buffer中的 flip()方法
Buffer 中有四个概念
- capacity
- position
- limit
- mark
capacity : 缓冲区数组的总长度
position : 下一个要操作的数据元素的位置.相当于 读/写指针
limit : 缓冲区数组中不可操作的下一个元素的位置, limit<=capacity
mark : 用于记录当前position 的上一次位置或者默认是0
filp()方法涉及 capacity , position, limit 三个参数
这里特别提及 limit 在写模式下表示最多能写入多少数据,此时和capacity相同。在读模式下表示最多能读多少数据,此时和缓存中的实际数据大小相同。
flip()方法
Buffer有两种模式,写模式和读模式。在写模式下调用flip()之后,Buffer从写模式变成读模式。
那么limit就设置成了position当前的值(即当前写了多少数据),postion会被置为0,以表示读操作从缓存的头开始读,mark置为-1。
也就是说调用flip()之后,读/写指针position指到缓冲区头部,并且设置了最多只能读出之前写入的数据长度(而不是整个缓存的容量大小)。
flip()源码:
public final Buffer flip() {
limit = position;
position = 0;
mark = -1;
return this;
}
这里看一下调用file()方法前后变化:
前:
后:
记住 position 的变化,很重要.
调用 flip()方法后, position 变成0