Netty ByteBuf转String

简述:

与NIO中的ByteBuffer类似,Netty中以ByteBuf作为它的字节容器。ByteBuf相当于ByteBuffer的升级。有兴趣可以看一看>>之前NIO中的ByteBuffer的文章
ByteBuffer存在一定的缺陷:

ByteBuffer长度固定,一旦分配,则容量不能动态扩展和收缩
ByteBuffer只有一个标识位置的指针,读写的时候需要手动的调用flip()方法来进行从写到读模式的切换,否则读出来的内容就是错误的。
ByteBuf维护了两个不同的索引:一个用于读取,一个用于写入。读取时,读索引递增读取的字节数。写入时,写索引会递增写入的字节数。初始时两个索引都为0。当两个索引相同时,也就是说数组中没有数据可读了。在试图读取会触发边界溢出异常。

转换代码:

int readableBytes = byteBuf.readableBytes();
CharSequence charSequence = byteBuf.readCharSequence(readableBytes, Charset.defaultCharset());
String string = charSequence.subSequence(0, charSequence.length()).toString();
System.out.print(string);

你可能感兴趣的:(java,并发编程,NIO)