在上一篇文章中,我介绍了关于GC机制中,GC在确认垃圾对象后,是如何回收这些垃圾对象的几种算法。现在介绍下GC机制一般是如何定位(或者叫做标记)出这些垃圾对象的。
我们先来问下自己,如何判介绍了断一个对象可以被回收。
答案很简单也很直白。这个对象再也不会被调用到了 ,那么就可以被回收了。
那么怎么判断一个对象再也不会被别人调用呢?
答案也很简单,只要其他的对象再也不持有当前对象的引用了,那么就可以被收回了。
结合以上的思路,基本就可以确定什么样的对象可以被标记为垃圾对象了。
基于此,通常被提到的用于定位垃圾对象的两种算法如下:
1、可达性分析法 Reachabbility Analysis
2、引用计数算法 Reference Counting
本文主要介绍第一种算法,第二种算法会在下篇文章中介绍。

可达性分析算法
可达性分析法大致思路是先确定出哪些对象一定不会被回收,然后将这些对象作为根,一次遍历这些根持有的引用,直至最终完整个森林。而这些遍历到的对象,就认为是可以到达,可以引用到的对象,将这些对象标记后,剩余未被标记的对象就可以认为是不可访问的垃圾对象了。
如下图所示


优点
这种方法无论是算法思路,还是算法的实现,都是非常简单 的。同时执行的误差非常小,可以处理包括循环引用(如上图中黄色的内存部分)在内的很多异常场景。因此自问世以来,大部分
的GC中,都可以看到该算法的影子。
缺点
1、简单是简单,可惜速度不够快。每次计算时都需要从根开始遍历。
2、对于只有极少数变量需要回收的场景,这种算法的性价比太低了。
3、对主程序的影响比较大,由于需要从根开始逐层探索,因此(防盗连接:本文首发自http://www.cnblogs.com/jilodream/ )在遍历的过程中,对象间的关系不能再发生变化,因此需要主程序暂停运行(这个时间段也常被称为Stop The World)。往往对于一些需要及时响应的场景,这种情况是非常不友好的。
那么究竟有哪些对象可以作为这个算法根存在呢?换句话说就是有哪些对象肯定不会被删除呢?
在JVM当中,有以下几种情况:
1、虚拟机栈中,栈帧中局部变量表所存放的变量引用
这些引用代表当前正在执行的方法中,所持有的引用。由于篇幅有限,如果你对为什么栈帧中的局部变量表的对象可以作为根存在疑问,可以看我的另外一篇关于虚拟机内存的文章:https://www.cnblogs.com/jilodream/p/6147791.html
2、方法区中静态属性引用的对象
这些引用表示的是类对象中,静态变量持有的引用。类一旦被加载,其中的静态变量不会随某一个实例对象的回收而回收。
3、方法区中常量的引用信息:方法区中常量引用的信息。
4、本地方法栈中,native方法正在使用的变量:虚拟机本地方法使用的变量。
以上对象并不是绝对的永远的可以作为算法的根存在。当类被卸载、常量被回收时,一些本来会被作为根的对象也会被回收。因此在回收时,具体以哪些对象作为可达性分析的根对象,虚拟机会根据情况再做决定。
由于篇幅有限,这里只介绍可达性分析法,至于引用计数算法我会放在下一篇文章中总结介绍。

JVM GC-----2、垃圾标记算法(一)的更多相关文章

  1. JVM GC-----3、垃圾标记算法(二)

    在上一篇文章中,介绍了在GC机制中,GC是以什么标准判定对象可以被标记的,以及最有效最常用的可达性分析法.今天介绍另外一种非常常用的标记算法,它的应用面也相当广泛.这就是:引用计数法 Referenc ...

  2. 【转载】Java性能优化之JVM GC(垃圾回收机制)

    文章来源:https://zhuanlan.zhihu.com/p/25539690 Java的性能优化,整理出一篇文章,供以后温故知新. JVM GC(垃圾回收机制) 在学习Java GC 之前,我 ...

  3. Java虚拟机(三)垃圾标记算法与Java对象的生命周期

    前言 这一节我们来简单的介绍垃圾收集器,并学习垃圾标记的算法:引用计数算法和根搜索算法,为了更好的理解根搜索算法,会在文章的最后介绍Java对象在虚拟机中的生命周期. 1.垃圾收集器概述 垃圾收集器( ...

  4. Java性能优化之JVM GC(垃圾回收机制)

    Java的性能优化,整理出一篇文章,供以后温故知新. JVM GC(垃圾回收机制) 在学习Java GC 之前,我们需要记住一个单词:stop-the-world .它会在任何一种GC算法中发生.st ...

  5. JVM中的垃圾回收算法GC

    GC是分代收集算法:因为Young区,需要回收垃圾对象的次数操作频繁:Old区次数上较少收集:基本不动Perm区.每个区特点不一样,所以就没有通用的最好算法,只有合适的算法. GC的4大算法 1.引用 ...

  6. 小师妹学JVM之:GC的垃圾回收算法

    目录 简介 对象的生命周期 垃圾回收算法 Mark and sweep Concurrent mark sweep (CMS) Serial garbage collection Parallel g ...

  7. JVM——GC(垃圾回收)算法

    一.垃圾回收的基本概念 垃圾回收(GC,Garbage Collection),指内存中不会再被使用的对象清理掉. 垃圾回收有很多种算法:如引用计数法.标记压缩法.复制算法.分代/分区的思想 二.垃圾 ...

  8. JVM学习--(四)垃圾回收算法

    我们都知道java语言与C语言最大的区别就是内存自动回收,那么JVM是怎么控制内存回收的,这篇文章将介绍JVM垃圾回收的几种算法,从而了解内存回收的基本原理. stop the world 在介绍垃圾 ...

  9. @JVM新一代的垃圾回收算法

    垃圾回收的瓶颈 传统分代垃圾回收方式,已经在一定程度上把垃圾回收给应用带来的负担降到了最小,把应用的吞吐量推到了一个极限.但是他无法解决的一个问题,就是Full GC所带来的应用暂停.在一些对实时性要 ...

随机推荐

  1. js设定延迟时间的函数

    1.如果想要在执行一个js函数之前延迟一段时间应该怎么做? 答:"setTimeout('update()',1000);" 其中update()函数就是延迟后执行的函数,后面的时 ...

  2. 后端python基础

  3. mongodb系列~mongodb数据迁移

    一 简介:今天来聊聊mongo的数据迁移二 迁移   1 具体迁移命令   nohup mongodump --port --db dbname --collection tablename --qu ...

  4. android 内存泄漏,以及检测方法

    1.为什么会产生内存泄漏 当一个对象已经不需要再使用本该被回收时,另外一个正在使用的对象持有它的引用从而导致它不能被回收,这导致本该被回收的对象不能被回收而停留在堆内存中,这就产生了内存泄漏. 2.内 ...

  5. MySQL 误操作后数据恢复(update,delete忘加where条件)【转】

    在数据库日常维护中,开发人员是最让人头痛的,很多时候都会由于SQL语句 写的有问题导致服务器出问题,导致资源耗尽.最危险的操作就是在做DML操作的时候忘加where条件,导致全表更新,这是作为运维或者 ...

  6. Python3学习笔记11-循环语句

    条件判断使用if,需要加上冒号,当条件判断为True时,执行if下的代码块,为false就什么也不做 只要var1不是0,非空字符串,非空list等,就判断为True.否则为False var1 = ...

  7. H3C SNMP OID

    有两种mib-style [1]老些的设备 cpu 使用率OID: .1.3.6.1.4.1.25506.2.6.1.1.1.1.6.slot  内存使用率OID: .1.3.6.1.4.1.2550 ...

  8. windows使用python原生组件包获取系统日志信息

    #coding=utf8 import sys import traceback import win32con import win32evtlog import win32evtlogutil i ...

  9. Android APP—— 开发入门教程

    一.SDK下载 下载:adt-bundle-windows-x86_64-20140702.zip(20140702 已经是最后版本了) 解压出来如下: 点击Eclipse安装 创建一个新的工作空间安 ...

  10. PYTHON-基本数据类型-数字类型,字符串类型,列表类型-练习

    # 字符串练习# 写代码,有如下变量,请按照要求实现每个功能 (共6分,每小题各0.5分)# name = " aleX"# # 1) 移除 name 变量对应的值两边的空格,并输 ...