`
disorder
  • 浏览: 5526 次
  • 性别: Icon_minigender_1
  • 来自: 北京
最近访客 更多访客>>
社区版块
存档分类
最新评论

垃圾收集算法

阅读更多
垃圾收集算法有很多种,有的是单独的算法,有的是多个算法的组合,这里谈的算法来自《深入Java虚拟机》一书:

引用计数:
这是一个比较古老的算法,原理和C++中的SmartPointer差不多,堆中的每个对象都有一个引用计数,创建一个对象之后,每有一个引用指向对象,该对象的引用计数被加1.当引用对象的引用计数为0时,对象变可以被垃圾收集。
这种方式虽然比较快,但是不能收集循环引用的对象。

跟踪收集:
将堆中的对象比作一个有多个树的森林,收集器启动时,从每棵树的跟节点开始向下追踪,并为每个遇到的对象做个标记,当追踪结束时,没有被标记的对象变可以作为垃圾收集。

这种收集算法是组合算法,一般会使用压缩和拷贝算法

压缩收集:
该收集策略主要是应对堆中的碎块。也就是在收集的过程中将堆中的碎片合并成为大的块。

拷贝收集:
该收集把所有的活动对象拷贝移动到一个新的区域。
好处是在追踪活动对象时,发现活动的就可以直接拷贝到新的区域,而不再用标记和清除,但是对于大的对象,频繁的拷贝会有效率问题,并且在拷贝期间,程序的执行一般要终止。

按代收集:
将堆中的对象按照生命周期的长短分为不同的“代”,对于不同的“代”,采取不同的收集算法。目前Java中的收集算法采用的都是按代收集算法。

自适应收集算法:
就是算法根据堆中的情形,相应的调整为合适的垃圾收集算法。太智能了,不知道有没有这样的算法。

火车算法:
目前的算法都是需要将程序停顿,并且无法控制何时停顿以及停顿的时间,也无法满足实时系统的要求,这种算法被称为破坏性的算法。为了达到非破坏性的收集方法是使用渐进式收集。渐进式收集不是试图一次性发现并回收所有不可达的对象,而是每次回收一部分,这样可以减少停顿的时间。
分享到:
评论

相关推荐

    垃圾收集算法的比较分析

    ### 垃圾收集算法的比较分析 #### 内存泄露与垃圾收集 在软件开发领域,内存管理一直是程序员面临的重大挑战之一。内存泄露(Memory Leak)是指在程序运行过程中,由于未能及时释放已不再使用的内存空间,导致这...

    深入理解JVM垃圾收集算法与垃圾收集器

    深入理解JVM垃圾收集算法与垃圾收集器

    基于实时性的Java虚拟机垃圾收集算法.pdf

    "基于实时性的Java虚拟机垃圾收集算法" 本文介绍了一种基于实时性的Java虚拟机垃圾收集算法,该算法旨在减少垃圾收集带来的不确定性暂停,并使用户可以指定一个时间段内垃圾收集导致应用程序暂停的最长时间。该算法...

    基于实时性的Java虚拟机垃圾收集算法

    ### 基于实时性的Java虚拟机垃圾收集算法:深入解析与优化 #### 引言 垃圾收集(Garbage Collection, GC)是Java语言的重要特性之一,它通过自动化管理内存,减轻了程序员处理内存分配与释放的负担,提高了代码的...

    Java虚拟机垃圾收集算法的研究和改进.pdf

    Java虚拟机(JVM)垃圾收集算法是Java语言的关键特性之一,负责自动管理内存,提高软件的可靠性,并减少开发者的内存管理负担。垃圾收集机制(GC)的核心目标是识别并回收程序中不再被引用的对象,即所谓的垃圾回收...

    JVM-性能调优垃圾收集算法虚拟机组成

    对于任何Java开发者来说,理解和掌握JVM的性能调优、垃圾收集算法以及虚拟机的组成是提高应用程序效率的关键。 首先,我们要了解JVM的组成部分。JVM主要包括以下几个部分: 1. **类加载器(ClassLoader)**:负责...

    JVM性能调优垃圾收集算法虚拟机组成.zip

    常见的垃圾收集算法有: 1. **标记-清除(Mark-Sweep)**:分为标记和清除两个阶段,标记出所有存活的对象,然后清除未被标记的对象。缺点是效率低,且会产生大量不连续的碎片。 2. **复制(Copying)**:将内存...

    jvm学习笔记(jvm内存模型&垃圾收集算法&类加载机制)

    在JVM的学习中,理解其内存模型、垃圾收集算法以及类加载机制至关重要。 1. **JVM内存模型** - **方法区**:也称为“永久代”,存储虚拟机加载的类信息、常量、静态变量等,是线程共享的区域。在Java 8之后,这...

    gc-viz, 几种垃圾收集算法的动画可视化.zip

    gc-viz, 几种垃圾收集算法的动画可视化 gc几种垃圾收集算法的动画可视化。makeopen MARK_SWEEP_GC.gifGIF输出需要安装 ImageMagick 。 编辑生成文件以选择不同的算法。 如果向该示例添加更多数据,则可能必须增加G

    论文研究-基于实时性的Java虚拟机垃圾收集算法.pdf

    提出了一种适用于实时性环境的Java虚拟机垃圾收集算法。该算法对增量式收集器中堆空间的划分方式、引用跟踪等方面进行了改进,以减少垃圾收集带来的不确定性暂停,并可以使用户指定一个时间段内垃圾收集导致应用程序...

    今天会是有Offer的一天么:面试时被问到的JAVA中的垃圾收集算法

    面试中被问到的垃圾收集算法是Java性能优化的重要方面,因为它直接影响程序的运行效率和内存使用。下面我们将深入探讨几种常见的垃圾收集算法。 1. 引用计数法 引用计数法是一种简单的垃圾收集策略,为每个对象维护...

    1_Java虚拟机(垃圾收集器和算法).pdf

    本文详细探讨了JVM中的垃圾收集器和垃圾收集算法,以帮助开发者深入理解Java虚拟机的内部运作机制。 垃圾收集(GC,Garbage Collection)是JVM的一个重要功能,用于自动释放不再使用的对象所占用的内存空间,以防止...

    基于嵌入式Java虚拟机的垃圾收集优化算法应用.pdf

    然而,不当的垃圾收集算法会导致应用性能降低,尤其是在内存受限的嵌入式系统中。 本论文聚焦于嵌入式Java虚拟机中的垃圾收集优化算法应用。在这份研究中,我们将探讨以下关键知识点: 1. Java虚拟机(JVM):JVM...

    基于JVM 中常见垃圾收集算法介绍

    垃圾收集算法在JVM中的应用 垃圾收集算法是Java虚拟机(JVM)中的一种机制,用于回收堆中的无用对象,以避免内存泄露和提高系统性能。JVM中的垃圾收集算法有四种:标记-清除算法、复制算法、标记-整理算法和分代...

    Java垃圾收集必备手册

    在这篇手册中,我们将深入探究 Java 垃圾收集的基础知识,包括垃圾收集的定义、垃圾收集算法、垃圾收集器的实现、垃圾收集优化等内容。 垃圾收集的定义 垃圾收集(Garbage Collection,简称 GC)是指在 Java 语言中...

    论文研究-CUDA平台下LISP2算法垃圾收集并行研究.pdf

    2. LISP2算法:LISP2是一种经典的垃圾收集算法,它能够有效地在内存管理中回收不再使用的内存对象。该算法的一个重要特性是不需要依赖操作系统的虚拟内存支持,对存活对象的压缩过程也不需要较大的辅助空间,同时...

    JVM初探- 内存分配、GC原理与垃圾收集器

    JVM内存管理是Java虚拟机的核心机制之一,其主要包含对象的创建、内存分配、...通过对内存分配策略、对象生死判定、垃圾收集算法和垃圾收集器的理解与应用,可以更好地掌握JVM的内存管理,从而提升应用性能和稳定性。

    Java虚拟机筑地篇之垃圾收集算法

    上一篇介绍了Java虚拟机的运行时内存区域,接下来将来学习下几种常见的垃圾收集算法,进入正题。 概述 在早期,人们就在思考GC(Garbage Collection,GC)需要完成的三件事: 哪些内存需要回收? 什么时候回收? ...

Global site tag (gtag.js) - Google Analytics