GC最初步的认识!!
Posted NewWorldForU
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了GC最初步的认识!!相关的知识,希望对你有一定的参考价值。
目录
1、JVM堆划分
JVM将堆内划分为eden,survior和Tenured/old空间,年轻代都在前俩,年老代在old
2、三种GC方式:
(1)Minor GC:用于清理年轻代区域,eden区域满了之后会触发一次Minor GC ,清理无用的对象,将有用的对象复制到Survivor1或者Survivor2中
(2)Major GC:用于清理老年代区域。
(3)Full GC:用于清理年轻代、年老代区域,成本较高,会对系统性能产生影响(优化主要针对这部分)
3、垃圾回收算法
3.1 标记清除算法:
标注和清除,该算法最大的问题是内存碎片化严重
3.2 复制算法:
为了解决 标记清除算法内存碎片化的缺陷而被提出的算法。按内存容量将内存划分为等大小
的两块。每次只使用其中一块,当这一块内存满后将尚存活的对象复制到另一块上去,把已使用 的内存清掉.
3.3 标记整理算法:
标记后不是清理对象,而是将存活对象移向内存的一端。然后清除端边界外的对象。
3.4 分代收集算法:
(1)新创建的对象大多数都会存储在eden中
(2)当eden中满了(达到一定比例)之后,则触发Minor GC ,将无用对象清理掉,将剩余对象复制到某个Survivor中,如survivor1,同时清空eden区
(3)当eden空间再次满了之后,会将s1中不能清空的对象存到s2中,同时将eden中不能清空的对象也存放在s2中,保证eden和s1均被清空。
(4)重复多次(默认15次)survivor中没有被清空的对象,则会复制到老年代old区中
当old区中满了,会触发一个完整的垃圾回收(Full GC,用于清理年轻代,年老代,成本较高,会对系统性能产生影响。
4、四种引用
(1)强引用(通过对象类型的变量直接引用
ClassB c = new ClassB();
(2)弱引用(WeakReference) 只要有 GC,弱引用引用的对象就会被回收。
WeakReference wr = new WeakReference(new ClassB());
(3)软引用(SoftReference)一般是FULL GC,软引用引用的对象会被回收。
SoftReference sr = new SoftReference(new ClassB());
(4)虚引用(PhantomReference) 当对象被回收时,可以得到通知。
5、俩种方式判断对象死亡
(1)引用计数法:给对象中添加一个引用计数器,每当一个地方引用他,计数器就+1,当引用消失,计数器-1,任何时候计数器为0的对象,就是不可能再被使用的。
问题:实现简单,效率高,可是解决不了对象直接互循环引用的问题。
(2)可达性分析算法:通过一系列的称为GC Roots 的对象作为起点,向下搜索,节点所走过的路径称为引用链,当没有任何引用链的时候,证明此对象不可用。在可达性算法中判定为不可达对象的时候,也不会“非死不可”,处于“缓刑”状态,一个对象真正的死亡要标记俩次:如果在“GC roots”中一个对象之间没有可达路径,则标记一次;随后进行一次筛选,筛选条件是此对象是否有必要执行finalize()。假如该对象没有重写该方法或者已经执行过该方法,都会被视为“没有必要执行”,会被标记第二次。finalize()是该对象最后逃离死亡命运的机会。
———— What is worth doing is worth doing well.
以上是关于GC最初步的认识!!的主要内容,如果未能解决你的问题,请参考以下文章