zoukankan      html  css  js  c++  java
  • JVM之GCRoots详解

    JVM之GCRoots详解
    目录
    面试题引子
    什么是垃圾
    判断对象是否可以被回收之引用计数法
    判断对象是否可以被回收之枚举根节点可达性分析
    Java中可以作为GC Roots的对象
    1. 面试题引子
    一面:GC Roots如何确定?哪些对象可以作为GC Roots?
    2. 什么是垃圾
    1.简单说就是内存中已经不再被使用到的空间就是垃圾

    3. 判断对象是否可以被回收之引用计数法
    Java中,引用和对象是有关联的。如果要操作对象则必须用引用进行。
    因此,很显然一个简单的办法是通过引用计数来判断一个对象是否可以回收。简单说,给对象中添加一个引用计数器,每当有一个地方引用它,计数器值加1,每当有一个引用失效时,计数器值减1。

    任何时刻计数器值为零的对象就是不可能再被使用的,那么这个对象就是可回收对象。

    那为什么主流的Java虚拟机里面都没有选用这种算法呢?其中最主要的原因是它很难解决对象之间相互循环引用的问题。


    4. 判断对象是否可以被回收之枚举根节点可达性分析
    为了解决引用计数法的循环引用问题,Java使用了可达性分析的方法。
    所谓"GCroots,或者说tracingGC的“根集合”就是一组必须活跃的引用。
    基本思路就是通过一系列名为”GCRoots”的对象作为起始点,从这个被称为GC Roots的对象开始向下搜索,如果一个对象到GCRoots没有任何引用链相连时,则说明此对象不可用。也即给定一个集合的引用作为根出发,通过引用关系遍历对象图,能被遍历到的(可到达的)对象就被判定为存活,没有被遍历到的就自然被判定为死亡。



    5. Java中可以作为GC Roots的对象
    虚拟机(栈帧中的本地变量表)中引用的对象
    方法区中类静态属性引用的对象
    方法区中常量引用的对象
    本地方法栈中JNI(即一般说的native方法)中引用的对象
    引用地址https://blog.csdn.net/weixin_41910694/article/details/90706652

  • 相关阅读:
    yolo_to_onnx ValueError: need more tan 1 value to unpack
    yolo_to_onnx killed
    C++ 实现二维矩阵的加减乘等运算
    Leetcode 1013. Partition Array Into Three Parts With Equal Sum
    Leetcode 1014. Best Sightseeing Pair
    Leetcode 121. Best Time to Buy and Sell Stock
    Leetcode 219. Contains Duplicate II
    Leetcode 890. Find and Replace Pattern
    Leetcode 965. Univalued Binary Tree
    Leetcode 700. Search in a Binary Search Tree
  • 原文地址:https://www.cnblogs.com/zhuyeshen/p/12579308.html
Copyright © 2011-2022 走看看