我们知道整个JVM内存中占用空间最大的结构就是堆了。如果你的电脑是双核4G那么JVM进程最多分配2G多点的内存,那么堆内存就会分配1G多一点。因为95%以上的对象都要放到堆中。如果使用的是4核8G的服务器就可以给JVM线程分配4到5个G的内存,那么堆内存可以分配为3到4个G,于是就可以给新生代至少分配2G内存,那么这样就大大降低了minor GC发生的频率,因为java本身是面向对象的语言,所以自然而然要为堆分配大量的内存,而且对堆的管理也是非常重要的。主要是涉及到堆中无用的对象的回收机制。方法区都是对类的登记,对类的信息的记录。类的实例化对象是放在堆中的。下面是堆中的结构:
我们从上面的图中可以看出堆的结构分为年轻代和老年代。
年轻代又分为Eden区和Survivor区,其中Survivor又分为from区和to区。
对于新new出来的对象一般都会放到年轻代的Eden区,如果Eden区满了之后就会发生一次minor GC,然后把剩余的活着的对象放到from区,如果再一次Eden区满之后又发生了minor GC会把剩余的对象连同from里面的对象都放到to区,然后清空from区,就这样来来回回,如果一个对象再from和to区之间来来回回经历了年龄次数超过了默认的次数15次,那么就会被放到老年代。如果老年代满了就会触发full GC清理整个堆内存,不管是年轻代还是老年代的垃圾。接下来在进一步分析垃圾回收机制之前我们看看什么是逃逸分析。
解释模式不会存在于缓存中,解释一次就执行一次,但是编译模式的热点代码会存于缓存中。