什么是GC
垃圾回收,全称garbage collector。
什么是垃圾?
一个对象没有任何引用指向它那就是垃圾。
垃圾回收器怎么找到垃圾?
1.引用计数:对象记录被引用指向的数量,变成0时就成为垃圾。不能解决循环引用问题
2.根可达算法(JVM使用):从程序运行的根对象往下找,能找到的都是有用的对象,剩下的就是垃圾
垃圾清除算法有哪些?
1.Mark-Sweep(标记清除法):标记垃圾直接清除,产生内存碎片,内存不连续
2.Copying(拷贝法):内存一分为二,回收垃圾后将有用对象拷贝到另一半内存,解决了标记清除法内存碎片问题,但是浪费内存空间
3.Mark-Compact(标记压缩法):将有用对象挪动、压缩到一边,解决了前两个算法问题,但是效率偏低,因为需要挪对象、清理垃圾、压缩内存
垃圾回收器
1.一共有10中垃圾回收器,JVM堆内存的管理是由垃圾回收器决定的,线上JVM调优必须清楚JDK版本和垃圾回收器种类。
2.windows查看使用哪种垃圾回收器命令,linux未提供:java -XX:+PrintCommandLineFlags -version
3.JDK8垃圾回收器组合
-xx:+UseSerialGC = Serial New (DefNew) + Serial Old
小型程序,默认情况下不会是这种选项,HotSpot会根据计算机配置和JDK版本自动选择收起器
-xx:+UseParNewGC = ParNew + SerialOld
这个组合已经很少用
-xx:+UseConcurrentMarkSweepGC = ParNew + CMS + Serial Old
-xx:+UseParallelGC = Parallel Scavenge + Parallel Old(1.8默认)
-xx:+UseG1GC = G1
4.内存分代模型
新生代:老年代 = 1 :2
5.分代规则
新创建的对象在新生代,没经过一次垃圾回收,存货下来的对象年龄+1,当达到一定程度,会进入老年代
6.分代应用回收算法
新生代:频繁生成对象,但存活对象少,应用复制算法,复制到survivor1、survivor2
老年代:存活对象多,应用标记清除或标记标记压缩算法
7.分代回收模型
新生成对象进入stack中,然后进入eden区,经过一次GC进入survivor1,再经过一次GC进入survivor2,再经过一次回收进入survivor1... 可以通过-XX:MaxTenuringThreshold配置最大年龄,达到最大年龄进入old(一般垃圾回收最大年龄默认15,CMS默认6)
8.GC概念
9.对象回收模型
新new对象放入栈中,如果不使用直接pop,不需要经过GC,效率很高。不放入栈中,看对象是否够大,够大放入老年代,经过FULLGC回收。不够大放入TLAB,最终进入新生代,经过几次GC进入老年代或者被回收。