Java虚拟机学习——垃圾收集算法
上一篇 /
下一篇 2012-10-12 15:35:36
/ 个人分类:Java
(?4gN2v!R2K.`5X0 1、标记 - 清除算法
9j6CR5|@5S&z(y2W051Testing软件测试网4@-FR&d lL 标记清除算法是最基础的收集算法,其他收集算法都是基于这种思想。标记清除算法分为“标记”和“清除”两个阶段:首先标记出需要回收的对象,标记完成之后统一清除对象。51Testing软件测试网LbJ ^ X
51Testing软件测试网w
^2E5q/Jjr3r![ 它的主要缺点:
&jC$MKq~!G U"l$wNW0P"v+V[5W VL0 ① 标记和清除过程效率不高51Testing软件测试网`Q.G$A5Qf
51Testing软件测试网DIW5D9O5X ② 标记清除之后会产生大量不连续的内存碎片。
c4}(ye1Q(ky051Testing软件测试网v_
R"J&~|T;X
51Testing软件测试网&Qm#{.[wrd?$E#T\
2、复制算法51Testing软件测试网Z2h
PGvK^;@R?\
它将可用内存容量划分为大小相等的两块,每次只使用其中的一块。当这一块用完之后,就将还存活的对象复制到另外一块上面,然后在把已使用过的内存空间一
次清理掉。这样使得每次都是对其中的一块进行内存回收,不会产生碎片等情况,只要移动堆订的指针,按顺序分配内存即可,实现简单,运行高效。
V5`O]MN{7B0 主要缺点:51Testing软件测试网6f6KN"y$r J
内存缩小为原来的一半。51Testing软件测试网+h6Gga$|&yu
51Testing软件测试网o\dk*v;e)yB8lg
s'G6tp$IgGW051Testing软件测试网:~gT8Y ~_,qEG 3、标记 - 整理算法
(GPa.Cc%YxLB/C^051Testing软件测试网;\)Pp%}zg)dNQ`(X 标记操作和“标记-清除”算法一致,后续操作不只是直接清理对象,而是在清理无用对象完成后让所有存活的对象都向一端移动,并更新引用其对象的指针。51Testing软件测试网t8l;lc%R9i*Pz4Y(|
c-{3xT:T/}w$A#dVX0 主要缺点:
#JA!OK&Hu^0PE5Y\Kp0 在标记-清除的基础上还需进行对象的移动,成本相对较高,好处则是不会产生内存碎片。
)j5aF}C5T y:O7}0
fO4tjhIosm0
,X:z:B`8Zep"K0 4、引用计数算法51Testing软件测试网5m:Dx&KZ!N
引用计数收集器采用的是分散式管理方式,通过计数器记录对象是否被引用。当计数器为0时说明此对象不在被使用,可以被回收。
\ |(B1}C+Op0 主要缺点:
+NT N
^ u
W1Y0 循环引用的场景下无法实现回收,例如下面的图中,ObjectC和ObjectB相互引用,那么ObjectA即便释放了对ObjectC、ObjectB的引用,也无法回收。sunJDK在实现GC时未采用这种方式。
|.t(F*Qv0
jJ:Tk#y,E` _ m&E3]t0 本文出自:http://blog.csdn.net/java2000_wl/article/details/802229351Testing软件测试网
s6JK i2_
收藏
举报
TAG: