美文网首页
JVM.003.垃圾回收器

JVM.003.垃圾回收器

作者: InitialX | 来源:发表于2019-02-27 10:19 被阅读0次

    阅读原文:https://blog.csdn.net/singc/article/details/108646348

    1 JVM内存模型

    谈到垃圾回收,我们先回顾下JVM的内存组成:

    线程隔离性 内存类型 用途
    线程隔离 1.本地方法栈 存储JVM的native方法
    2.虚拟机栈 存储类方法里的局部变量、返回结果链接、程序执行的字节位置等,其生命周期与线程一致
    3.程序计数器 根据虚拟机栈中存储的字节位置,在线程切换后找到上次执行位置。
    线程共享 1.堆 存储对象实例和数组
    2.方法区(永久代) 存储类加载文件、常量、静态变量等。在Java8中永久代被移除,由“元数据区”取代
    直接内存 NIO等 在JDK1.4时引入了NIO,可以不通JVM而由Native方法直接在系统内存进行IO操作,显著提升了效率
    在这里插入图片描述

    垃圾回收主要是针对堆内存进行!

    2 垃圾回收与算法

    2.1 回收对象

    垃圾回收对象通常是指已死亡的变量。常用的确认算法有2种:

    • 引用计数法
    • 可达性分析法

    2.2 回收算法

    • 标记算法
    • 复制算法
    • 标记-整理算法

    垃圾回收器按照其算法特性不同,其在各分代中的使用也不同。

    • 新生代(young generation)有三种GC:
      -Serial(串行) : 只会使用1个cpu或线程进行垃圾回收,而且回收过程中,其他所有线程都必须暂停,直至回收结束,被戏称为“stop the world”。
      应用场景:用户端,由于是单线程运作,没有线程交互的大开销,故而效率很高,回收时间可以控制在毫秒级别,对于用户而言几乎没有停顿感。
      -ParNew
      Paralle Scavenge(scavenge:打扫)

    • 老年代(teunred generation)也有三种GC:
      CMS(Concurrent Mark Sweep)
      Serial Old(MSC)
      Paralle Old

    • 另外还有一个GC在新生代和老年代都会用到—— G1。

    from 《深入理解Java虚拟机》

    如图所示共有7种GC,如果有连线则表示二者可以搭配使用。

    未完待续...

    相关文章

      网友评论

          本文标题:JVM.003.垃圾回收器

          本文链接:https://www.haomeiwen.com/subject/zahxuqtx.html