直接内存不受 JVM 内存回收管理,是虚拟机的系统内存,常见于 NIO 操作时,用于数据
缓冲区,分配回收成本较高,但读写性能高,不受 JVM 内存回收管理。
举例
当上传一个较大文件(200M)对比常规IO和NIO时。使用NIO(直接内存)的时间要远远低于常规IO的操作时长。
NIO是与JVM有一定关系的 。
传统IO的数据传输流程图如下
可以看到,当使用传统阻塞IO上传文件时,会在操作系统和java堆中的内存中都创建一个缓冲区进行磁盘文件的读写,这是非常耗时的。
直接内存NIO的数据传输流程图如下
可以看到
在这个里面主要使用到了一个直接内存,不需要在堆中开辟空间进行数据的拷贝,jvm 可以直接操作操作系统中的内存,从而使数据读写传输更快。
什么是直接内存(NIO)
追豆者2024-05-16 7:09
相关推荐
电商数据girl12 分钟前
酒店旅游类数据采集API接口之携程数据获取地方美食品列表 获取地方美餐馆列表 景点评论CircleMouse12 分钟前
基于 RedisTemplate 的分页缓存设计ktkiko1118 分钟前
顶层架构 - 消息集群推送方案zybsjn24 分钟前
后端系统做国际化改造,生成多语言包Unity官方开发者社区1 小时前
《Cryptical Path》开发诀窍:像玩游戏一样开发一款类Rogue游戏_星辰大海乀1 小时前
表的设计、聚合函数IT成长史1 小时前
deepseek梳理java高级开发工程师微服务面试题-进阶版zkmall1 小时前
Java + 鸿蒙双引擎:ZKmall开源商城如何定义下一代B2C商城技术标准?陌路物是人非1 小时前
uniapp取消浏览自动填充獨枭1 小时前
使用 163 邮箱实现 Spring Boot 邮箱验证码登录