Java虚拟机学习——垃圾收集算法

上一篇 / 下一篇  2012-10-12 15:35:36 / 个人分类:Java

$EDm.P%yc.O"g)[0  1、标记 - 清除算法

"O gs9|px:DW051Testing软件测试网h |T%Wx{b9Ih

  标记清除算法是最基础的收集算法,其他收集算法都是基于这种思想。标记清除算法分为“标记”和“清除”两个阶段:首先标记出需要回收的对象,标记完成之后统一清除对象。

S"?/[|;?D*P+Y051Testing软件测试网3g#IX,JKv9|9t\b

  它的主要缺点:51Testing软件测试网ds7Q"Iu_l%C8H

1H4WhUV m&Z0  ① 标记和清除过程效率不高51Testing软件测试网rLBa3yX9od)V

.z] ]'?9N{CXx C0  ② 标记清除之后会产生大量不连续的内存碎片。

K:S)P~2o$[Rb0

P,R+L+Pu?(y'Bh0

n3z1q~0~~k0

  2、复制算法51Testing软件测试网2E _9E Ut*js1R/TL

   它将可用内存容量划分为大小相等的两块,每次只使用其中的一块。当这一块用完之后,就将还存活的对象复制到另外一块上面,然后在把已使用过的内存空间一 次清理掉。这样使得每次都是对其中的一块进行内存回收,不会产生碎片等情况,只要移动堆订的指针,按顺序分配内存即可,实现简单,运行高效。51Testing软件测试网ZM~%t/Gr

  主要缺点:

cy9ke!_-w)D0

  内存缩小为原来的一半。51Testing软件测试网:x/SH\^W:YXo"|

51Testing软件测试网#re*y,qF3B*kO

51Testing软件测试网}H$cK[ vaf G

51Testing软件测试网1n/l/~2j B?

  3、标记  - 整理算法51Testing软件测试网yyve;xWRj

51Testing软件测试网'e A9mpS-`X0]j

  标记操作和“标记-清除”算法一致,后续操作不只是直接清理对象,而是在清理无用对象完成后让所有存活的对象都向一端移动,并更新引用其对象的指针。51Testing软件测试网1X:hGT'\!L

51Testing软件测试网 m zL)G^7h/r

  主要缺点:51Testing软件测试网,s#x;D,U/u-j7`'F'l]

51Testing软件测试网v(??m\W*pk

  在标记-清除的基础上还需进行对象的移动,成本相对较高,好处则是不会产生内存碎片。51Testing软件测试网 m5a"a#zg

51Testing软件测试网EP{:HT+I

X$a5X sZfn5WY0

  4、引用计数算法51Testing软件测试网KR!~5Rk^w

  引用计数收集器采用的是分散式管理方式,通过计数器记录对象是否被引用。当计数器为0时说明此对象不在被使用,可以被回收。

;}ZPN(l#`Gf*|0

  主要缺点:51Testing软件测试网IJ n7U~VC5x

  循环引用的场景下无法实现回收,例如下面的图中,ObjectC和ObjectB相互引用,那么ObjectA即便释放了对ObjectC、ObjectB的引用,也无法回收。sunJDK在实现GC时未采用这种方式。

A4g U N6w/z0S#I0

H8A ^W8n:Sn)T*V4f0

  本文出自:http://blog.csdn.net/java2000_wl/article/details/8022293

9l@H N!X2|$\0

TAG:

 

评分:0

我来说两句

Open Toolbar