`
jason61719
  • 浏览: 39496 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

Java回收算法

阅读更多

Java 语言规范没有明确地说明JVM 使用哪种垃圾回收算法,但是任何一种垃圾收集算法一般要做2 件基本的事情:(1 )发现无用信息对象;(2 )回收被无用对象占用的内存空间,使该空间可被程序再次使用。

大多数垃圾回收算法使用了根集(root set) 这个概念;所谓根集就量正在执行的Java 程序可以访问的引用变量的集合( 包括局部变量、参数、类变量) , 程序可以使用引用变量访问对象的属性和调用对象的方法。垃圾收集首选需要确定从根开始哪些是可达的和哪些是不可达的,从根集可达的对象都是活动对象,它们 不能作为垃圾被回收,这也包括从根集间接可达的对象。而根集通过任意路径不可达的对象符合垃圾收集的条件,应该被回收。下面介绍几个常用的算法。

1、   引用计数法 (Reference Counting Collector)

引用计数法是唯一没有使用根集的垃圾回收的法,该算法使用引用计数器来区分存活对象和不再使用的对象。一般来说,堆中的每个对象对应一个引用计数器。当每一次创建一个对象并赋给一个变量时,引用计数器置为1 。当对象被赋给任意变量时,引用计数器每次加1 当对象出了作用域后( 该对象丢弃不再使用) ,引用计数器减1 ,一旦引用计数器为0 ,对象就满足了垃圾收集的条件。

基于引用计数器的垃圾收集器运行较快,不会长时间中断程序执行,适宜地必须 实时运行的程序。但引用计数器增加了程序执行的开销,因为每次对象赋给新的变量,计数器加1 ,而每次现有对象出了作用域生,计数器减1

2 tracing 算法 (Tracing Collector)

tracing 算法是为了解决引用计数法的问题而提出,它使用了根集的概念。基于tracing 算法的垃圾收集器从根集开始扫描,识别出哪些对象可达,哪些对象不可达,并用某种方式标记可达对象,例如对每个可达对象设置一个或多个位。在扫描识别过程中,基于tracing 算法的垃圾收集也称为标记和清除(mark-and-sweep) 垃圾收集器.

 

3 compacting 算法(Compacting Collector)

为了解决堆碎片问题,基于tracing 的垃圾回收吸收了Compacting 算法的思想,在清除的过程中,算法将所有的对象移到堆的一端,堆的另一端就变成了一个相邻的空闲内存区,收集器会对它移动的所有对象的所有引用进行更新,使得这些引用在新的位置能识别原来 的对象。在基于Compacting 算法的收集器的实现中,一般增加句柄和句柄表。

4 copying 算法 (Coping Collector)

该算法的提出是为了克服句柄的开销和解决堆碎片的垃圾回收。它开始时把堆分成 一个对象 面和多个空闲面, 程序从对象面为对象分配空间,当对象满了,基于coping 算法的垃圾 收集就从根集中扫描活动对象,并将每个 活动对象复制到空闲面( 使得活动对象所占的内存之间没有空闲洞) ,这样空闲面变成了对象面,原来的对象面变成了空闲面,程序会在新的对象面中分配内存。

一种典型的基于coping 算法的垃圾回收是stop-and-copy 算法,它将堆分成对象面和空闲区域面,在对象面与空闲区域面的切换过程中,程序暂停执行。

5 generation 算法(Generational Collector)
  stop-and-copy 垃圾收集器的一个缺陷是收集器必须复制所有的活动对象,这增加了程序等待时间,这是coping 算法低效的原因。在程序设计中有这样的规律:多数对象存在的时间比较短,少数的存在时间比较长。因此,generation 算法将堆分成两个或多个,每个子堆作为对象的一代(generation) 。由于多数对象存在的时间比较短,随着程序丢弃不使用的对象,垃圾收集器将从最年轻的子堆中收集这些对象。在分代式的垃圾收集器运行后,上次运行存活下来的对象移到下一最高代的子堆中,由于老一代的子堆不会经常被回收,因而节省了时间。

6 adaptive 算法(Adaptive Collector)

在特定的情况下,一些垃圾收集算法会优于其它算法。基于Adaptive 算法的垃圾收集器就是监控当前堆的使用情况,并将选择适当算法的垃圾收集器。

分享到:
评论

相关推荐

    java虚拟机垃圾回收算法

    这是一篇关于java虚拟机垃圾回收算法的论文。

    java C#垃圾回收算法分析

    本文将深入探讨Java和C#中的垃圾回收算法,帮助开发者理解其工作原理和优化策略。 首先,我们要明确垃圾回收的基本概念。在程序运行过程中,会动态分配内存来存储对象。当一个对象不再被引用时,它就变成了垃圾。...

    Java demo 算法笔记

    此外,Java的异常处理机制、垃圾回收机制以及IO流等也是开发者必须掌握的关键知识点。 在算法方面,Java提供了丰富的数据结构和算法实现,如排序算法(冒泡排序、快速排序、归并排序)、查找算法(二分查找、哈希...

    天津理工大学_操作系统_存储器的分配与回收算法实现_实验报告.doc

    操作系统存储器分配和回收算法实现实验报告 在计算机操作系统中,存储器分配和回收是非常重要的功能,它们直接影响着系统的性能和安全。本实验报告的目的是通过设计和实现存储器分配和回收算法,来模拟操作系统的...

    Java垃圾回收新算法刍探.pdf

    本文提出了一种新的垃圾回收算法,该算法可以一定程度上改善和提高Java垃圾回收的性能。 Java与C/C++的对比: 1. 内存管理机制:Java中的内存管理机制基于垃圾回收机制,而C/C++中的内存管理机制基于手动管理。 2....

    Java经典算法(包你们划算)

    Java作为一门广泛应用于企业级开发和互联网应用的语言,其经典算法是每个Java程序员必备的技能之一。本资源包“Java经典算法(包你们划算)”提供了丰富的学习材料,旨在帮助开发者提升算法理解和应用能力。主要包含...

    Java垃圾回收算法的简易模拟实现.zip

    健壮性与高性能:Java通过垃圾回收机制确保内存的有效管理,同时也能通过JIT编译器优化来提升运行时性能。 标准库丰富:Java拥有庞大的类库,如Java SE(Java Standard Edition)包含基础API,用于开发通用应用...

    JVM之基本的垃圾回收算法汇总

    在Java虚拟机(JVM)中,垃圾回收(Garbage Collection, GC)是自动管理内存的重要机制,它负责识别并释放不再使用的对象所占用的内存空间。...理解这些基础的垃圾回收算法有助于我们更好地调试和调优Java应用程序。

    Java新生代老年代的划分及回收算法

    垃圾回收算法的选择基于对象的生命周期和内存区域的特点。标记清除算法虽然简单,但效率低且可能导致大量碎片;复制算法提高了效率,但仅适用于新生代;标记整理算法适合老年代,能有效处理高存活率的情况。 在进行...

    福高(天津)Java程序算法面试题

    "福高(天津)Java程序算法面试题"这个标题表明这是一个与Java编程语言相关的面试问题集,特别关注的是算法方面。福高(天津)可能是一家公司在天津的分支机构,它对求职者的技术能力有较高的要求,尤其是Java编程和...

    Java入门--简述Java语言回收机制

    - 常见的垃圾回收算法包括标记-清除算法、复制算法以及标记-整理算法等。这些算法各有优缺点,JVM会根据实际情况选择最合适的算法。 5. **Finalization机制**: - 在Java中,可以通过重写`finalize()`方法来进行...

    垃圾回收算法与实现,Turling

    在这个主题中,Turing垃圾回收算法是一个重要的研究方向,它在Java等语言的虚拟机实现中扮演着关键角色。 垃圾回收(Garbage Collection, GC)是编程语言中的一种机制,用于自动管理程序的内存。它自动检测和回收...

    Java垃圾回收原理

    垃圾回收器通过可达性分析算法来判断对象是否还被引用。如果一个对象没有任何引用指向它,那么这个对象就可以被视为垃圾,并可被垃圾回收器回收。 #### 三、Java中的垃圾回收器 ##### 3.1 Serial Collector Serial...

    垃圾回收算法

    ### 垃圾回收算法详解 #### 引言 垃圾回收机制是现代编程语言中一项重要的功能,旨在自动管理程序的内存使用,避免程序开发者手动管理内存带来的复杂性和潜在错误。这一机制最早出现在Lisp语言中,随着技术的发展...

    垃圾回收算法与实现

    垃圾回收算法篇详细介绍了多种垃圾回收算法,包括标记-清除算法、引用计数法、复制算法、标记-压缩算法、保守式垃圾回收、分代垃圾回收、增量式垃圾回收和RCImmix算法等。这些算法各有其特点和适用场景,它们是垃圾...

    java高级之垃圾回收机制

    通过深入理解JVM内存模型以及不同的垃圾回收算法,可以帮助我们更好地优化程序性能,提高代码质量。在实际开发过程中,合理利用JVM提供的工具和技术,可以有效地避免内存泄漏等问题,提升系统的稳定性和可靠性。

    垃圾回收相关算法.pdf

    本文将深入探讨几种垃圾回收算法,帮助读者理解JVM底层原理。 1. 引用计数算法: 引用计数算法是最直观的垃圾回收策略,它为每个对象分配一个引用计数器,每当有对象引用它时,计数器加1;当引用失效时,计数器减1...

Global site tag (gtag.js) - Google Analytics