nio中ByteBuffer使用

创建ByteBuffer
java 复制代码
 ByteBuffer buffer = ByteBuffer.allocate(10);
 
 // 字符串转 bytebuffer
 ByteBuffer buffer01 = Charset.defaultCharset().encode("hello world");
ByteBuffer buffer02 = ByteBuffer.wrap("hello".getBytes());
ByteBuffer buffer03 = StandardCharsets.UTF_8.encode("hehe");

//  buffer转字符串
CharBuffer decode = StandardCharsets.UTF_8.decode(buffer02);
ByteBuffer结构
  • position : 读取或者写入的指针位置
  • limit : 读取或者写入限制位置
  • capacity : 容量
常用方法
  • put() :往buffer里面添加数据,,, 也可以通过channel读
  • get() : 会获取一个字节的数据,,指针往后走
  • get(i) : 获取指定位置的数据,,指针不会动
  • flip() : 切换到读模式,,,, position变为0 ,,limit变为数据长度
  • clear() : 切换到写模式 ,, position变成0,,limit变成 capacity
  • compact() : 压缩,有的时候数据读了一部分,没读完,又需要写入新的数据,compact将position变成剩余数据的长度,limit变成capacity
  • mark() 和 reset(): 有的部分需要反复的读,,用mark()设置一个标记, reset()回滚到那个标记
  • hasRemaining() : 是否有剩余字节可读写
  • rewind() : 将position变为0
相关推荐
Luo_xguan4 小时前
一、Netty-高并发IO底层原理(5种主要的IO模型)
java·服务器·netty·nio
007php0079 小时前
某游戏大厂的常用面试问题解析:Netty 与 NIO
java·数据库·游戏·面试·职场和发展·性能优化·nio
爱吃烤鸡翅的酸菜鱼6 天前
如何掌握【Java】 IO/NIO设计模式?工厂/适配器/装饰器/观察者模式全解析
java·开发语言·后端·设计模式·nio
Full Stack Developme18 天前
java.nio 包详解
java·python·nio
编啊编程啊程24 天前
【004】生菜阅读平台
java·spring boot·spring cloud·dubbo·nio
编啊编程啊程25 天前
兼职管理平台
java·spring boot·rpc·dubbo·nio
编程岁月1 个月前
java面试-0136-BIO、NIO、AIO区别?
java·面试·nio
TitosZhang1 个月前
BIO、NIO、AIO详解
java·redis·nio
编啊编程啊程1 个月前
gRPC从0到1系列【20】
java·rpc·kafka·dubbo·nio
编啊编程啊程1 个月前
gRPC从0到1系列【19】
java·spring boot·rpc·dubbo·nio