CV工程师自赎之路--Java回收机制小记(一)

Java垃圾回收机制

垃圾回收重点回收堆中的对象及方法区
判断对象存活的方法:
1、 引用计数法—给对象添加一个引用计数器,当对象添加一个引用时,计数器+1,引用失效时-1;当对象的计数器数量为0时,对象可回收.
优点:快、方便、实现简单
缺点:对象互相引用时(A.instance=B 同时 B.instance=A),很难判断对象是否该回收
2、 可达性分析—通过称为GC roots的对象作为起始点,从这些节点开始向下搜索(引用链),当一个对象到GCRoots没有任何链相连时,对象不可用,可回收。
作为 GC Roots 的对象包括下面几种: 当前虚拟机栈中局部变量表中的引用的对象 当前本地方法栈中局部变量表中的引用的对象 方法区中类静态属性引用的对象 方法区中的常量引用的对象。
各种引用(Reference)
传统定义:Reference 中存储的数据代表的是另一块内存的起始地址。
强引用–不回收 a=b
软引用–缓存–即将oom时候回收软引用–SoftReference
弱引用–每次gc就凉凉–WeakReference—threadLocal、WeakHashMap
虚引用–被垃圾回收的时候收到一个通知,如果一个对象只具有虚引用,那么它和没有任何引用一样,任何时候都可能被回收。 虚引用主要用来跟踪对象被垃圾回收器回收的活动

垃圾回收算法
复制算法:
在这里插入图片描述
优点:简单高效、不会出现碎片化问题(内存不连续产生内存碎片)
缺点:内存利用率低,对象存活多时,效率低。
新生代Eden from to 8:1:1
标记清除算法:
在这里插入图片描述
优点:利用率百分之百
缺点:标记和清除的效率都不高(比对复制算法)
会产生大量的不连续的内存碎片
标记整理算法:
在这里插入图片描述
优点:利用率百分之百,没有内存碎片
缺点:标记和清除的效率都不高
效率相对标记-清除要低

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值