阅读原文: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。
如图所示共有7种GC,如果有连线则表示二者可以搭配使用。
未完待续...
网友评论