随笔 - 303  文章 - 0  评论 - 3  阅读 - 15万

JVM非运行时共享内存之直接内存

  直接内存(Direct Memory) 并不是虚拟机运行时数据区的一部分。为何存在呢?观察下两图进行对比:  

                

                

  有没有似曾相识?!很多架构的设计都基于这种思想,提高性能和效率。NIOBuffer提供一个可以直接访问系统物理内存的类——DirectBuffer。

                

  普通的ByteBuffer仍在JVM堆上分配内存,其最大内存受到最大堆内存的 限制。而DirectBuffer直接分配在物理内存中,并不占用堆空间。在访问普通的ByteBufferr时,系统总是会使用一个内核缓冲区进行操作。而DirectBuffer所处的位置,就相当于这个内核缓冲区。因此,使用DirectBuffer是一种更加接近内存底层的方法,所以它的速度比普通的ByteBuffer更快。

  通过使用堆外内存,可以带来以下好处:

     1. 改善堆过大时垃圾回收效率,减少停顿。Full GC时会扫描堆内存,回收效率和堆大小成正比。Native的内存,由OS负责管理和回收。

     2. 减少内存在Native堆和JVM堆拷贝过程,避免拷贝损耗,降低内存使用。

     3. 可突破JVM内存大小限制。

 

posted on   池塘里洗澡的鸭子  阅读(9)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
历史上的今天:
2022-05-15 Docker核心原理之数据卷
2021-05-15 Spring Boot部署之 web项目war包形式
2021-05-15 nginx反向代理初体验
2021-05-15 Linux系统安装tomcat9服务(含jdk的安装)
2021-05-15 Nginx安装启动
2021-05-15 tip8:CentOS8安装ftp服务器
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示