堆外内存和堆内存是如何分配的?
发布时间:2023-02-28 17:00:00
发布人:qyf
堆内内存(on-heap memory)完全遵守JVM虚拟机的内存管理机制,堆内内存 = 新生代+老年代+持久代,我们采用垃圾回收器(GC)统一进行内存管理,平时GC会去频繁的回收新生代的对象,也就是minor GC.然后GC会在某些特定的时间点进行一次彻底回收,也就是Full GC,GC会对所有分配的堆内内存进行扫描,在这个过程中会对JAVA应用程序的性能造成一定影响,还可能会产生Stop The World。
我们在jvm参数中只使用-Xms,-Xmx等参数就可以设置堆的大小和最大值,和堆内内存相对应,堆外内存就是把内存对象分配在Java虚拟机的堆以外的内存,这些内存直接受操作系统管理(而不是虚拟机),这样做的结果就是能够在一定程度上减少垃圾回收对应用程序造成的影响。
我们经常用java.nio.DirectByteBuffer对象进行堆外内存的管理和使用,它会在对象创建的时候就分配堆外内存.DirectByteBuffer类是在Java Heap外分配内存,对堆外内存的申请主要是通过成员变量unsafe来操作