9.NIO 核心1:缓冲区(Buffer)
static xxxBuffer allocate(int capacity):创建一个容量为capacity 的xxxBuffer对象
样例:
@Test
public void test01() {
//1.分配一个缓冲区,容量设置为10
ByteBuffer buffer = ByteBuffer.allocate(10);
//返回当缓冲区的当前位置
System.out.println(buffer.position());//0
//返回缓冲区的limit界限位置
System.out.println(buffer.limit());//10
//返回缓冲区的容量
System.out.println(buffer.capacity());//10
System.out.println("=================================");
//2.往缓冲区中放数据
String name = "wumengda";
buffer.put(name.getBytes());
//返回当缓冲区的当前位置
System.out.println(buffer.position());//8
//返回缓冲区的limit界限位置
System.out.println(buffer.limit());//10
//返回缓冲区的容量
System.out.println(buffer.capacity());//10
System.out.println("=================================");
//3.Buffer flip() 将缓冲区的界限设置为当前位置,并将当前位置设置为0:可读模式
buffer.flip();
//返回当缓冲区的当前位置
System.out.println(buffer.position());//0
//返回缓冲区的limit界限位置
System.out.println(buffer.limit());//8
//返回缓冲区的容量
System.out.println(buffer.capacity());//10
//4.get数据获取
char ch= (char) buffer.get();
System.out.println(ch);//w
//返回当缓冲区的当前位置
System.out.println(buffer.position());//1
//返回缓冲区的limit界限位置
System.out.println(buffer.limit());//8
//返回缓冲区的容量
System.out.println(buffer.capacity());//10
}
样例2:clear的使用
@Test
public void test02() {
ByteBuffer buffer = ByteBuffer.allocate(10);
String name = "wumengda";
buffer.put(name.getBytes());
//返回当缓冲区的当前位置
System.out.println(buffer.position());//8
//返回缓冲区的limit界限位置
System.out.println(buffer.limit());//10
//返回缓冲区的容量
System.out.println(buffer.capacity());//10
System.out.println("=================================");
buffer.flip();
byte[] b = new byte[2];
buffer.get(b);
System.out.println(new String(b));//wu
//返回当缓冲区的当前位置
System.out.println(buffer.position());//2
//返回缓冲区的limit界限位置
System.out.println(buffer.limit());//8
//返回缓冲区的容量
System.out.println(buffer.capacity());//10
System.out.println("=================================");
//重点1:clear 清空缓冲区,发现并不是真的清空,是将position置为0,limit和capacity置为最大,此时如果再放值,会进行覆盖
buffer.clear();
//返回当缓冲区的当前位置
System.out.println(buffer.position());//0
//返回缓冲区的limit界限位置
System.out.println(buffer.limit());//10
//返回缓冲区的容量
System.out.println(buffer.capacity());//10
char ch = (char) buffer.get();
System.out.println(ch);//w
//返回当缓冲区的当前位置
System.out.println(buffer.position());//1
//返回缓冲区的limit界限位置
System.out.println(buffer.limit());//10
//返回缓冲区的容量
System.out.println(buffer.capacity());//10
}
样例3:mark和resert的使用(标记和重置)
@Test
public void test02() {
ByteBuffer buffer = ByteBuffer.allocate(10);
String name = "wumengda";
buffer.put(name.getBytes());
//返回当缓冲区的当前位置
System.out.println(buffer.position());//8
//返回缓冲区的limit界限位置
System.out.println(buffer.limit());//10
//返回缓冲区的容量
System.out.println(buffer.capacity());//10
System.out.println("=================================");
buffer.flip();
byte[] b = new byte[2];
buffer.get(b);
System.out.println(new String(b));//wu
//返回当缓冲区的当前位置
System.out.println(buffer.position());//2
//返回缓冲区的limit界限位置
System.out.println(buffer.limit());//8
//返回缓冲区的容量
System.out.println(buffer.capacity());//10
System.out.println("=================================");
//重点:标记当前位置,后面可以resert
buffer.mark();
byte[] by = new byte[3];
buffer.get(by);
System.out.println(new String(by));//men
//返回当缓冲区的当前位置
System.out.println(buffer.position());//5
//返回缓冲区的limit界限位置
System.out.println(buffer.limit());//8
//返回缓冲区的容量
System.out.println(buffer.capacity());//10
System.out.println("=================================");
buffer.reset();
if (buffer.hasRemaining()){
System.out.println("buffer剩余:"+buffer.remaining());//6
}
//返回当缓冲区的当前位置
System.out.println(buffer.position());//2
//返回缓冲区的limit界限位置
System.out.println(buffer.limit());//8
//返回缓冲区的容量
System.out.println(buffer.capacity());//10
}
直接内存的使用场景:
1.有很大的数据需要存储,他的生命周期又很长
2.适合频繁操作的io操作,比如网络并发场景
@Test
public void test3(){
ByteBuffer buffer=ByteBuffer.allocate(1024);
//判断是不是直接内存
System.out.println(buffer.isDirect());//false
//创建直接内存
ByteBuffer byteBuffer=ByteBuffer.allocateDirect(1024);
System.out.println(byteBuffer.isDirect());//true
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 字符编码:从基础到乱码解决