JVM垃圾回收机制(一)[通俗易懂]

JVM垃圾回收机制(一)[通俗易懂]一、什么是垃圾?1:引用计数算法:给对象中加一个引用计数器,每当有一个引用指向它时,计数器的值就加一,引用失效时,计数器的值就减一。当该对象引用计数器等于0的时候就被视为垃圾。该算法存在很大的缺陷,若两个对象存在互相引用,则两者的引用计数器都不为0,都不能被GC。如:publicclassReferenceCountingGC{publi

大家好,又见面了,我是你们的朋友全栈君。

一、什么是垃圾?

1:引用计数算法:给对象中加一个引用计数器,每当有一个引用指向它时,计数器的值就加一,引用失效时,计数器的值就减一。当该对象引用计数器等于0的时候就被视为垃圾。
该算法存在很大的缺陷,若两个对象存在互相引用,则两者的引用计数器都不为0,都不能被GC。
如:

public class ReferenceCountingGC{
                public Object instance = null;
                public static void testGC(){
                      ReferenceCountingGC objA = new ReferenceCountingGC();
                      ReferenceCountingGC objB = new ReferenceCountingGC();
                      objA.instance = objB;
                      objB.instance = objA;
                      objA = null;
                      objB = null;
                      System.gc();
         }
        }

JVM显然不会采用这种算法。

2:可达性分析算法:通过一系列的称为“GC Roots”的对象作为起始点,从这些节点向下搜索,搜索所走过的路径称为引用链(Reference Chain),当一个对象从GC Roots不可达的时候,该对象则不可用,会被GC。
GC Roots包含:

  • 虚拟机栈(栈帧中的本地变量表)中引用的对象。
  • 方法区中类静态属性引用的对象。
  • 方法区中常量引用的对象。
  • 本地方法栈中JNI(即Native方法)引用的对象。

二、垃圾收集算法

1:标记清除算法(Mark-Sweep):首先标记出所有需要回收的对象,在标记完成后统一回收。
这里写图片描述

该算法的优缺点其实都很明显:效率较高,但是标记清楚之后会产生大量不连续的内存碎片,导致以后如果有大对象需要分配时无法找到足够大的连续内存空间,触发另一次GC动作。

2:复制算法(Copying):将可用的内存划分为可用的两块,每次只使用其中一块,当这一块内存满了之后,将这一块当中存活的对象复制到另外一块上去,再把原来的这一块空间一次清理掉,这样使得每次只对半个空间进行GC,简单高效,代价是内存缩小为原来的一半。

这里写图片描述

3:标记整理算法(Mark-compact):与标记清除算法一样,首先标记出所有需要回收的对象,然后再将所有存货的对象都向一端移动,然后直接清理掉端边界以外的内存。
这里写图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/134176.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • poe网线水晶头接法顺序_水晶头和网络插座接线是一样的吗

    poe网线水晶头接法顺序_水晶头和网络插座接线是一样的吗现在有很多有POE网线供电的网络设备例如监控摄像头布线只需要拉一根网线就可以解决供电和数据线路,很多路由器AP也有POE供电的只需要接一根网线就可以,POE供电的设备水晶头针脚一般用蓝,白蓝,白棕,棕,的这四根的其中两根或者四根,具体看设备的规范了,有些POE设备用蓝色和棕色传输。…

    2022年9月17日
    1
  • DNS负载均衡技术

    DNS负载均衡技术负载均衡技术能够平衡服务器集群中所有的服务器和请求应用之间的通信负载,根据实时响应时间进行判断,将任务交由负载最轻的服务器来处理,以实现真正的智能通信管理和最佳的服务器群性能,从而使网站始终保持运行和保证其可访问性。  为了充分利用现有服务器软件的种种优势,负载均衡最好是在服务器软件之外来完成。而最早使用的负载均衡技术是通过DNS服务中的随机名字解析来实现的。这就是通常所说的DNS负载均衡

    2022年7月14日
    12
  • LinearGradient线性渲染

    LinearGradient线性渲染

    2021年12月17日
    38
  • rand()函数的用法[通俗易懂]

    rand()函数的用法[通俗易懂]C++中rand()函数的用法1、rand()不需要参数,它会返回一个从0到最大随机数的任意整数,最大随机数的大小通常是固定的一个大整数。2、如果你要产生0~99这100个整数中的一个随机整数,

    2022年8月2日
    4
  • JavaEE完整框架[通俗易懂]

    JavaEE完整框架[通俗易懂]JavaEE是一套使用Java进行企业级Web应用开发的大家一致遵循的工业标准。JavaEE平台提供了一个基于组件的方法来加快设计、开发、装配及部署企业应用程序。相对于Microsoft的.NET,Sun公司的Java*E和一系列标准、技术及协议更接近或更满足互联网在智能化Web服务方面对开放性、分布性和平台无关性的要求。JavaEE的13种核心技术规范:1、JDBC(JavaDatabase)数据库连接JDBC是一组用于执行SQL的JavaAPI,为访问不同的数据库提供了一种统一

    2022年7月7日
    18
  • 轻量级过程改进之综述「建议收藏」

    轻量级过程改进之综述

    2022年1月26日
    44

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号