平时代码中创建的对象,一般分为两种:
一种是短期存活的,分配在JVM堆内存中,迅速使用完就会被垃圾回收。
另外一种是长期存活的,需要一直生存在JVM堆内存里,让程序后续不停的去使用。
第一种短期存活的对象,是在Java堆内存的新生代里的。第二种长期存活的对象,是在Java堆内存的老年代里的。大部分正常对象都优先在新生代分配内存。

1.什么情况下会触发垃圾回收?

一个比较常见的场景可能是这样的,假设我们写的代码中创建了N多对象,然后导致Java堆内存里囤积了大量的对象。然后这些对象都是之前有人引用,比如各种各样的方法中的局部变量,但是现在也都没人引用了。这个时候,如果新生代我们预先分配的内存空间,几乎都被全部对象给占满了!此时假设我们代码继续运行,他需要在新生代里去分配一个对象,怎么办?发现新生代里内存空间都不够了!这个时候,就会触发一次新生代内存空间的垃圾回收,新生代内存空间的垃圾回收,也称之为“Minor GC”,有的时候我们也叫“Young GC”,他会尝试把新生代里那些没有人引用的垃圾对象,都给回收掉。

2.长期存活的对象会躲过多次垃圾回收

如果一个实例对象在新生代中,成功的在15次垃圾回收之后,还是没被回收掉,就说明他已经15岁了。这是对象的年龄,每垃圾回收一次,如果一个对象没被回收掉,他的年龄就会增加1。所以如果对象在新生代中成功躲过10多次垃圾回收,成为一个“老年人”,那么就会被认为是会长期存活在内存里的对象。然后他会被转移到Java堆内存的老年代中去,顾名思义,老年代就是放这些年龄很大的对象。

3.老年代会垃圾回收吗?

答案是肯定的,因为老年代里的对象也有可能随着代码的运行,不再被任何人引用了,就需要被垃圾回收。

4.对象分配的一些复杂机制

① 新生代垃圾回收之后,因为存活对象太多,导致大量对象直接进入老年代;
② 特别大的超大对象直接不经过新生代就进入老年代;
③ 动态对象年龄判断机制;
④ 空间担保机制;