GC概述
垃圾回收是一种自动的存储管理机制。当一些被占用的内存不再需要时,将其释放,以让出空间,这种存储管理机制,就叫做垃圾回收机制。可以很大程度减轻程序员的负担和错误。
通常在堆(heap) 和 元空间(metaspace)需要GC机制。
GC触发条件:当Eden区满了触发Minor GC,将存活的对象转移到survivor区,每次GC对象的年龄加1,。当年龄满15或survivor区满一半是,对象被移到老年区。当老年代空间不足时触发Full GC。
什么是垃圾?
没有引用指向的对象
GC:
1.哪些对象要被回收 which
2.什么时候被回收 when
3.采用什么方式回收 how
1.哪些对象要被回收 which
1.引用计数法【了解】
给对象添加了一个引用计数器,引用一次 +1 引用失效 -1
计数器0 说明这个对象可以被回收
缺点:
循环引用 ,会导致 这个对象回收不了
Obejcet a = new Object(); +1
Obejcet b = new Object(); +1
a.xxx=b +1
b.xxx=a +1
a.xxx=b +1
a =>2
b =>3
a=null a =>1
b=null b =>2
2.根节点可达性分析
从GCroot出发可达到的对象都是存活的对象,反之则是需要回收的垃圾。
什么是GCroot?
1.栈(stack)
2.方法区(Method Area)
3.native stack
2.什么时候被回收 when
gc算法:
1.标记清除: mark-sweep
标记: 标记哪些对象要被清除【根节点可达性分析】
清除:垃圾对象进行清除
缺点: 内存碎片
stop the world =》 stw 暂停应用
2.标记整理:
标记: 标记哪些对象要被清除【根节点可达性分析】 进行清除
整理:移动活的对象 进行内存整理
3.复制:
1.把内存分成大小相同的两片
2.浪费了一些内存
3.没碎片
3.采用什么方式回收 how
采用什么方式回收?
1.理论:=》 gc算法
2.落地:=》垃圾收集器
垃圾收集器 :
1.串行垃圾收集器
2.并行垃圾收集器
3.并发垃圾收集器
4.G1垃圾收集器【比较复杂】
1.串行垃圾收集器
1.一个线程处理垃圾回收
2.stw
app=>gc=>app
2.并行垃圾收集器
1.多个线程处理垃圾回收
2.比 串行垃圾收集器 stw时间短
3.并发垃圾收集器
你的程序线程 和 gc线程 并发执行
没有stw
分代算法:
年轻代 老年代
1.年轻代
1.串行
-Xms5m -Xmx5m -XX:+PrintGCDetails -XX:+UseSerialG
DefNew 年轻代 串行垃圾回收器
Tenured 老年代 串行垃圾回收器打印
2.ParNew(并行)
-Xms5m -Xmx5m -XX:+PrintGCDetails -XX:+UseParNewGC
ParNew 年轻代 并行垃圾回收器
Tenured 老年代 串行垃圾回收器打印
3.Parallel Scavenge(并发) jinfo
-Xms5m -Xmx5m -XX:+PrintGCDetails -XX:+UseParallelGC
PSYoungGen 年轻代 并发垃圾回收器
ParOldGen 老年代 并行垃圾回收器
2.老年代
1.串行 【用不了】
-Xms5m -Xmx5m -XX:+PrintGCDetails -XX:+UseSerialOldGC【参数没有找到】
2.Parallel old(并行)
-Xms5m -Xmx5m -XX:+PrintGCDetails -XX:+UseParallelOldGC
PSYoungGen 年轻代 并发垃圾回收器
ParOldGen 老年代 串行垃圾回收器打印
3.CMS(并发标记清除)
1.目的
gc =》 停顿的时间比较短
-Xms5m -Xmx5m -XX:+PrintGCDetails -XX:+UseConcMarkSweepGC
ParNew 年轻代 并发垃圾回收器
CMS 老年代 cms垃圾回收器