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.
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值