前言:在虚拟机的世界里面,内置了很多的垃圾收集器,但并不是说最先进的就是最好的。有一句话说的好“因地制宜”;
一、Epsilon收集器
是一个无操作的收集器,但是贴切的来说是“自动内存管理子系统”。但是一个垃圾收集器的工作不仅仅只有垃圾收集,还负责堆的管理与布局、对象的分配、与解释器的协作、与编译器的协作、与监控子系统协作等职责。传统的Java面临着内存占用大,在容器中启动时间长,即时编译等问题,Epsilon收集器加入了提前编译、面向应用的类数据共享等支持。
所以说,如果读者的应用只需要运行数分钟或者是数秒,只要Java虚拟机能正确分配内存,在堆耗尽之前就退出,那显得运行负载极小、没有任何回收行为的Epsilon收集器是一个很不错的选择。
二、收集器的权衡
三、大对象直接进入老年代
1、大对象直接被分配到了老年代分配,这样做的目的是为了避免在Eden区以及两个Survivor区之间来回复制,产生大量的内存复制操作。
2、只要老年代的连续空间大于新生代对象总大小或者历次晋升的平均大小,就会进行Minor GC,否则将进行Full GC。