`
Turandot
  • 浏览: 52333 次
  • 性别: Icon_minigender_1
  • 来自: 珠海
社区版块
存档分类
最新评论

垃圾收集算法

阅读更多

                  常用垃圾收集算法

 

    Java与C++之间有一堵由内存动态分配和垃圾收集技术所围成的高墙,墙外面的人想进去,墙里的人想出来。

 

    GC的历史远远比Java久远,1960年诞生的Lisp是第一门真正使用内存动态分配和垃圾收集技术的语言。

 

    程序员计数器,虚拟机栈,本地方法栈三个区域都是线程私有,随着线程而生,随线程而灭。栈中的栈帧随着方法的进入和退出而出栈和出栈。这几个区域不需要过多的考虑回收的问题,因为方法结束或线程结束时,内存就跟着回收了。垃圾收集关注的就是堆和方法区这部分内存。

 

      怎么判断对象一个对象是否“存活”?

         1 引用计数法:很难解决对象之间相互循环引用的问题。

         2 根搜索算法:从GC Roots到这个对象不可达时,则证明这个对象时不可用的。

 

      在Java语言里,可作为GC Roots的对象包括:

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

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

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

         4 本地方法栈中JNI (即一般说的Native方法)的引用的对象

 

    Java虚拟机规范中确实说过可以不要求虚拟机在方法区实现垃圾收集,方法区的垃圾收集主要回收两部分内容:废弃常量和无用的类。

 

       判断无用的类?满足以下三个条件:

         1 该类所有的实例都已被回收,也就是Java堆中不存在该类的任何实例。

         2 加载该类的ClassLoader已经被回收。

         3 该类对应的java.lang.Class 对象没有任何地方被引用,无法在任何地方通过反射访问该类的方法。

 

 

    垃圾收集算法是一个慢慢优化的过程,常用如下:

    

     1 标记-清除算法(Mark-Sweep)

        

           该算法简单,但是效率不高和产生大量碎片

      

     2 复制算法(Copying)

          

           该算法较标记-清除算法效率有提高,但是会浪费局部的内存。

           

           现在的商业虚拟机都采用这种收集算法来回收新生代(HotSpot中Eden,Form,To比例为8:1:1)。

   

     3 标记-整理算法(Mark-Compact)

 

           避免复制算法中执行较多的复制操作和浪费局部的空间。主要用于老年代收集。

          

 

     4 分代收集算法(Generational Collection)

 

           当前的商业虚拟机的垃圾收集都采用分代收集算法,根据各个年代的特点采用最适当的收集算法。

 

 

分享到:
评论

相关推荐

    垃圾收集算法的比较分析

    ### 垃圾收集算法的比较分析 #### 内存泄露与垃圾收集 在软件开发领域,内存管理一直是程序员面临的重大挑战之一。内存泄露(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