jvm原理及性能调优系列(GC和内存分配策略)

垃圾回收器

  垃圾回收相关搜索相关算法:

  1、引用计数器:有缺点,如果对象之间互相引用,GC不能够主动回收对象。(JAVA没有采用

  2、跟搜索算法:通过一些列名字为“GC ROOTS”的对象作为起点,从这些起点开始搜索,到达终点如果没有引用,那么对象可以释放。(JAVA C#等采用的

  永久代的垃圾回收主要包含两种:

  1、废弃常量  当常量已经进入常量池,并且没有任何引用可以回收。

  2、无用的类  当满足以下条件成为“无用类”:

        1>、该类所有的实例都被收回,也就是java堆中不存在该类的实例

        2>、加载该类的ClassLoader都被收回

        3>、该类对应的java.lang.Class没有被引用,无法通过反射访问该类的方法

  垃圾回收相关算法:

  1、标记清除算法 效率较低,会产生不连续的碎片,可能触发垃圾回收器以前进行垃圾回收。

  2、复制算法 将内存分成两部分,当需要回收时来回转移内存,并进行清除。一般,效率较高,当存活率较高时,内存占用较大。

  3、标记整理算法 标记完成后不是直接清理,而是让标记对象转向另一端进行直接清理。

  4、分代收集算法  根据对象的存活周期采用不同的垃圾清理方法。

  垃圾收集器:

  Serial收集器:单线程,当其工作时,其他线程停止工作。缺点:效率低  优点:简单高效

  ParNew收集器:就是Serial收集器的多线程版本

    原文作者:JVM
    原文地址: http://www.cnblogs.com/guohui-y/p/5206978.html
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞