charbuffer的flip()函数对CharsetEncoder编码的影响?

没有注释掉cbuff.flip() ;这一句

import java.nio.charset.Charset ;
import java.nio.charset.CharsetEncoder ;
import java.nio.charset.CharsetDecoder ;
import java.nio.CharBuffer ;
import java.nio.ByteBuffer ;
import java.nio.charset.CharacterCodingException ;

public class Test 
{
    public static void main(String args[]) throws CharacterCodingException
    {
        Charset cn = Charset.forName("GBK") ;
        CharsetEncoder cnEncoder = cn.newEncoder() ;
        CharsetDecoder cnDecoder = cn.newDecoder() ;
        CharBuffer cbuff = CharBuffer.allocate(8) ;
        cbuff.put('哈') ;
        cbuff.put('哈') ;
        cbuff.put('哈') ;
        cbuff.flip() ;
        ByteBuffer bbuff = cnEncoder.encode(cbuff) ;
        System.out.println(bbuff.capacity()) ;
        System.out.println(bbuff.limit()) ;
    }
}

最后两句输出的capacitylimit就是6 ,这个我理解,
但是我如果注释掉cbuff.flip()这一句,最后两句输出的capacitylimit分别是10和5, 我想了一下, charbuffer分了8个字符的缓冲区, 占用了3个, 剩下的5个,用encode()编码成了bytebuffer,capacity是10, 但是limit为什么会是capacity的一半?这个的理由是什么呢?

阅读 4.6k
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
logo
101 新手上路
子站问答
访问
宣传栏