跟踪收集器

跟踪收集器采用的为集中式的管理方式,全局记录对象之间的引用状态,执行时从一些列GC  Roots的对象做为起点,从这些节点向下开始进行搜索所有的引用链,当一个对象到GC  Roots 没有任何引用链时,则证明此对象是不可用的。
下图中,对象Object6、Object7、Object8虽然互相引用,但他们的GC Roots是不可到达的,所以它们将会被判定为是可回收的对象。

可作为GC Roots 的对象包括:

虚拟机栈(栈帧中的本地变量表)中的引用对象。

方法区中的类静态属性引用的对象

方法区中的常量引用的对象

本地方法栈中JNI的引用对象。

主要有复制、标记清除、标记压缩三种实现算法。

1. 标记 – 清除算法

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

它的主要缺点:

①.标记和清除过程效率不高

②.标记清除之后会产生大量不连续的内存碎片。

2. 复制算法

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

主要缺点:

内存缩小为原来的一半。

3. 标记  - 整理算法

标记操作和“标记-清除”算法一致,后续操作不只是直接清理对象,而是在清理无用对象完成后让所有存活的对象都向一端移动,并更新引用其对象的指针。

主要缺点:

在标记-清除的基础上还需进行对象的移动,成本相对较高,好处则是不会产生内存碎片。

引用计数收集器

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

主要缺点:

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

本系列:

  • Java虚拟机学习(1):体系结构 内存模型
  • Java虚拟机学习(2):垃圾收集算法
from: http://www.importnew.com/22223.html

Java虚拟机学习(2):垃圾收集算法相关推荐

  1. java虚拟机学习-JVM调优总结-新一代的垃圾回收算法(11)

    java虚拟机学习-深入理解JVM(1) java虚拟机学习-慢慢琢磨JVM(2) java虚拟机学习-慢慢琢磨JVM(2-1)ClassLoader的工作机制 java虚拟机学习-JVM内存管理:深 ...

  2. Java虚拟机学习(8):查看JVM参数及值的命令行工具

    查看JVM各个参数值方式 1. HotSpot vm中的各个globals.hpp文件  查看jvm初始的默认值及参数 globals.hpp globals_extension.hpp c1_glo ...

  3. Java虚拟机学习(7):对象内存分配与回收

    对象优先在Eden上分配 大多数情况下,对象优先在新生代Eden区域中分配.当Eden内存区域没有足够的空间进行分配时,虚拟机将触发一次 Minor GC(新生代GC).Minor GC期间虚拟机将E ...

  4. Java虚拟机学习(6):对象访问

    对象访问会涉及到Java栈.Java堆.方法区这三个内存区域. 如下面这句代码: 1 Object objectRef = new Object(); 假设这句代码出现在方法体中,"Obje ...

  5. Java虚拟机学习(5):内存调优

    JVM调优主要是针对内存管理方面的调优,包括控制各个代的大小,GC策略.由于GC开始垃圾回收时会挂起应用线程,严重影响了性能,调优的目是为了尽量降低GC所导致的应用线程暂停时间. 减少Full GC次 ...

  6. Java虚拟机学习(4):JDK可视化监控工具

    1.JConsole JConsole工具在JDK/bin目录下,启动JConsole后,将自动搜索本机运行的jvm进程,不需要jps命令来查询指定.双击其中一个jvm进程即可开始监控,也可使用&qu ...

  7. Java虚拟机学习(3): 类加载机制

    类加载机制 JVM把class文件加载的内存,并对数据进行校验.转换解析和初始化,最终形成JVM可以直接使用的Java类型的过程就是加载机制. 类从被加载到虚拟机内存中开始,到卸载出内存为止,它的生命 ...

  8. Java 虚拟机学习笔记 | 类加载过程和对象的创建流程

    前言 创建对象是 Java 语言绕不开的话题,那么对象是如何创建出来的呢?我们今天就来聊一聊.对象创建第一步就是检查类是否加载,而类的加载又牵扯到类的加载过程.如果单说对象的创建而绕开类的加载过程,感 ...

  9. Java虚拟机学习(1):体系结构 内存模型

    一:Java技术体系模块图 二:JVM内存区域模型 1.方法区 也称"永久代" ."非堆",  它用于存储虚拟机加载的类信息.常量.静态变量.是各个线程共享的内 ...

最新文章

  1. 计算机辅助教学导学设计研究,《计算机辅助教学》实验报告
  2. NYOJ 655 光棍的yy
  3. C++中的private protected public区别
  4. Animation插值器:解决Android Animation 循环执行的停顿问题
  5. Google 开源技术protobuf 简介与样例
  6. Hinton领衔谷歌大脑新研究,拯救被认成步枪的乌龟
  7. WINDOWS上svn服务器自动部署
  8. CentOS7 配置防火墙规则应对漏洞扫描
  9. c语言无符号数最大值和最小值,c语言 int最大值是多少?
  10. 腾讯云数据库团队:MySQL AHI 实现解析
  11. 使用PIXI制作简单canvas逐帧动画的心得
  12. 9、Python xlsxwriter模块
  13. 用docker跑机器学习环境
  14. vue使用组件化思想实现一个简单的购物车页面
  15. ⑤CSS浮动学成在线网实例
  16. 如何用Phaser实现一个全家福拼图H5
  17. windows phone 7开发日志(正题二,字体)
  18. 叽叽歪歪JS乱七八糟的方法——web(二)
  19. 无线网络技术—FAT AP(放装型AP)简单配置
  20. 小甲鱼python教程视频怎么样-小甲鱼零基础入门学习Python视频教程全套96集

热门文章

  1. 转载-centos网络配置(手动设置,自动获取)的2种方法
  2. 为什么使用 Vuetify?
  3. http://nlp.stanford.edu:8080/parser/index.jsp
  4. 解读思科2014-19年全球移动互联网发展趋势报告(1)
  5. Adnroid体系与系统架构
  6. C语言遥控器程序,红外遥控
  7. python窗体设置italic_007萝卜头学python:Python GUI 之Tkinter
  8. android 从底部网上的平移动画_Android属性动画,看完这篇够用了吧
  9. 如何设计登录接口,十分钟内连续登录5次失败,需要等待30分钟才能登录
  10. debian安装python3_debian上安装python3.6