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
相关推荐
没有bug.的程序员2 天前
Java IO 与 NIO:从 BIO 阻塞陷阱到 NIO 万级并发
java·开发语言·nio·并发编程·io流·bio
与遨游于天地2 天前
NIO的三个组件解决三个问题
java·后端·nio
独自破碎E7 天前
解释一下NIO、BIO、AIO
java·开发语言·nio
学习是生活的调味剂9 天前
Java IO模型之BIO和NIO分析
java·nio
不知疲倦的仄仄10 天前
第二天:深入理解 Selector:单线程高效管理多个 Channel
java·nio
不知疲倦的仄仄11 天前
第一天:从 ByteBuffer 内存模型到网络粘包处理实战
java·网络·nio
zfj32111 天前
java BIO、NIO、AIO用法样例
java·开发语言·nio·bio·aio
程序猿ZhangSir17 天前
深入理解 BIO,NIO,AIO 三者的用途和区别?Select,poll,epoll 操作系统函数简介
java·spring·nio
禾叙_19 天前
【NIO】ByteBuffer
前端·html·nio
heartbeat..19 天前
Java NIO 详解(Channel+Buffer+Selector)
java·开发语言·文件·nio