JVM源码分析之堆外内存(直接内存)

  • Post author:
  • Post category:其他




1、堆外内存定义

内存对象分配在JVM中堆以外的内存,也可以称为直接内存,这些内存直接受操作系统管理(而不是JVM),这样做的好处是能够在一定程度上减少垃圾回收对应用程序造成的影响。一般我们使用Unsafe和NIO包下ByteBuffer来创建堆外内存。



2、为什么使用堆外内存

1、减少了垃圾回收

使用堆外内存的话,堆外内存是直接受操作系统管理( 而不是虚拟机 )。这样做的结果就是能保持一个较小的堆内内存,以减少垃圾收集对应用的影响。

2、提升复制速度(io效率)

堆内内存由JVM管理,属于“用户态”;而堆外内存由OS管理,属于“内核态”。如果从堆内向磁盘写数据时,数据会被先复制到堆外内存,即内核缓冲区,然后再由OS写入磁盘,使用堆外内存避免了这个操作。

image



3、堆外内存申请

JDK的ByteBuffer类提供了一个接口allocateDirect(int capacity)进行堆外内存的申请,底层通过unsafe.allocateMemory(size)实现。Netty、Mina等框架提供的接口也是基于ByteBuffer封装的。

import java.nio.ByteBuffer;
public class DirectOom {
       
    public static void main(String[] args) {
           
        //直接分配128M的直接内存(100M)        
        ByteBuffer bb = ByteBuffer.allocateDirect(128*1024*1204);    
    }
}

源码分析如下:</



版权声明:本文为m0_57768035原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。