java.nio.ByteBuffer中flip,rewind,clear方法的区别

Posted DHpie

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java.nio.ByteBuffer中flip,rewind,clear方法的区别相关的知识,希望对你有一定的参考价值。

对缓冲区的读写操作首先要知道缓冲区的下限、上限和当前位置。下面这些变量的值对Buffer类中的某些操作有着至关重要的作用:
  1. limit:所有对Buffer读写操作都会以limit变量的值作为上限。

  2. position:代表对缓冲区进行读写时,当前游标的位置。

  3. capacity:代表缓冲区的最大容量(一般新建一个缓冲区的时候,limit的值和capacity的值默认是相等的)。

flip、rewind、clear这三个方法便是用来设置这些值的。

clear方法


技术分享public final Buffer clear()
技术分享
{
技术分享    position = 0; 
//重置当前读写位置
技术分享
    limit = capacity; 
技术分享    mark = -1;  
//取消标记
技术分享
    return this;
技术分享}

技术分享
clear方法将缓冲区清空,一般是在重新写缓冲区时调用。


flip方法


技术分享public final Buffer flip() {
技术分享    limit
= position;
技术分享    position
= 0;
技术分享    mark
= -1;
技术分享    
return this;
技术分享}


反转缓冲区。首先将限制设置为当前位置,然后将位置设置为 0。如果已定义了标记,则丢弃该标记。 常与compact方法一起使用。通常情况下,在准备从缓冲区中读取数据时调用flip方法。


rewind方法


1技术分享public final Buffer rewind() {
2技术分享    position = 0;
3技术分享    mark = -1;
4技术分享    return this;
5技术分享}


以上三种方法均使用final修饰,java.nio.Buffer的所有子类均使用同一种flip、clear和rewind机制。





以上是关于java.nio.ByteBuffer中flip,rewind,clear方法的区别的主要内容,如果未能解决你的问题,请参考以下文章

是否存在允许动态增长和扩展 java.nio.ByteBuffer 的 ByteBuffer 实现?

java.nio.ByteBuffer.slice() 线程行为?

java.nio.ByteBuffer.array(ByteBuffer.java:959) 处的 java.lang.UnsupportedOperationException

《Netty官方指南》把Netty当做一个通用的库

哪些 JVM 不支持直接 java.nio.ByteBuffer?

直接 java.nio.ByteBuffer 与 Java 数组性能测试