JVM可以使用的内存分外两种:堆内存和堆外内存。堆内存完全由JVM负责分配和释放,堆外内存的存在是为了能直接分配和释放内存,提高效率。
堆外内存优点:
对外内存由于避免了数据从用户态向内核态的拷贝,提升IO效率,另外还可以节约大量的堆内内存,减少GC次数。
堆外内存缺点:
分配和回收堆外内存比分配和回收堆内存耗时;(解决方案:通过对象池避免频繁地创建和销毁堆外内存)
堆外内存原理:
堆内内存由JVM管理,是在“用户态”时处理;而堆外内存由OS管理,是在“内核态”时处理。如果从堆内向磁盘写数据时,数据会被先复制到堆外内存,即内核缓冲区,然后再由OS写入磁盘。而直接使用堆外内存避免了数据从用户态向内核态的拷贝。
参考资料:
https://blog.csdn.net/yangguosb/article/details/77870791?utm_source=copy