Java垃圾收集器知识整理

很早就看了垃圾收集器,只是东看看西看看。之前系统的学习过,不过过一段时间就又忘记了,现在再次整理一下吧。废话说完了,进入正题。

我们通过回答下面三个问题来理解Java的垃圾回收机制:

  • 哪些内存需要回收?
  • 什么时候需要回收?
  • 如何回收?

哪些内存需要回收

答:堆和方法区的内存需要回收。
Java运行时的数据区域可以分为5个:堆、方法区、程序计数器、虚拟机栈、本地方法栈。
其中程序计数器、虚拟机栈、本地方法栈这三个的内存是随着线程结束之后就自然跟着回收了。不必考虑垃圾回收的问题。
而堆、方法区是由所有线程共享的数据区域。随着程序运行会在上面动态的创建对象,所以需要回收这两部分的内存。

什么时候需要回收

“死”去的对象需要回收。通过下面两个方法判断对象是否“死”掉:

  1. 引用计数算法
  2. 可达性分析算法

引用计数算法

就是对于创建的每一个对象都有一个与之关联的计数器,这个计数器记录着该对象被使用的次数,垃圾收集器在进行垃圾回收时,对扫描到的每一个对象判断一下计数器是否等于0,若等于0,就会释放该对象占用的内存空间,同时将该对象引用的其他对象的计数器进行减1操作。
采用引用计数器进行垃圾回收,最大的缺点就是不能解决循环引用的问题,例如一个父对象持有一个子对象的引用,子对象也持有父对象的引用,这种情况下,父子对象将一直存在于JVM的堆中,无法进行回收。

可达性分析算法

通过一系列称为”GC Roots”的对象作为起点,从这些节点开始向下搜索,搜索所有走过的路径称为引用链,当一个对象到GC Roots没有任何引用链相连时(从GC Roots到此对象不可达),则证明此对象是不可用的。
可作为GC Roots的对象包括:

  • 虚拟机栈中所引用的对象
  • 方法区中类静态属性引用的对象
  • 方法区中常量引用的对象
  • 本地方法栈中JNI引用的对象

引用多说两句

无论是引用计数算法可达性分析算法,判断对象的存货都与“引用”有关。引用分为下面4种:

  • 强引用:普遍存在的对象,比如“Object object = new Object()”只要强应用还存在,就不会回收引用的对象。
  • 软引用:还有用但并非必须的对象,第二次垃圾回收的时候才进行回收,第二次回收还是内存不足就会报OOM
  • 弱引用:非必须的对象,只能生存到下一次垃圾回收之前。
  • 虚引用:无法通过一个虚引用来获得一个对象的实例。设置虚引用的目的是这个对象在回收时会收到一个系统通知。

如何回收

有以下的方法可以进行回收:

  1. 标记清除算法:http://www.jianshu.com/p/b0f5d21fe031
  2. 复制算法
  3. 标记整理算法
  4. 分代收集算法

(未完待续)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值