`
heipark
  • 浏览: 2091496 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

(转)聊聊 java gc

    博客分类:
  • Java
 
阅读更多

 

GC,先给一个定义:

当一个电脑上的动态内存不再需要时,就应该予以释放,以让出内存,这种内存资源管理,称为垃圾回收(garbage collection)

实际上,为了保证gc能够在不同的平台得以实现,java规范本身并没有对gc的具体行为做约束,比如什么时候gc,采用什么算法gc等等…下边,我们先来看看一些常用或者曾经常用的gc算法。

什么时候GC

    • 引用计数

引用计数存储对特定对象的所有引用数,也就是说,当应用程序创建引用以及引用超出范围时,jvm必须适当增减引用数。当某对象的引用数为0时,便可以进行垃圾收集。

    • 对象引用遍历

早期的jvm使用引用计数,现在大多数jvm采用对象引用遍历。对象引用遍历从一组对象开始,沿着整个对象图上的每条链接,递归确定可到达(reachable)的对象。如果某对象不能从这些根对象的一个(至少一个)到达,则将它作为垃圾收集。在对象遍历阶段,gc必须记住哪些对象可以到达,以便删除不可到达的对象,这称为标记(marking)对象。 然后,gc要删除不可到达的对象。删除时,有些gc只是简单的扫描堆栈,删除未标记的对象,并释放它们的内存以生成新的对象,这叫做清除(sweeping)。这种方法的问题在于内存会分成好多小段,而它们不足以用于新的对象,但是组合起来却很大。因此,许多gc可以重新组织内存中的对象,并进行压缩(compact),形成可利用的空间。 为此,gc需要停止其他的活动活动。这种方法意味着所有与应用程序相关的工作停止,只有gc运行。结果,在响应期间增减了许多混杂请求。另外,更复杂的 gc不断增加或同时运行以减少或者清除应用程序的中断。有的gc使用单线程完成这项工作,有的则采用多线程以增加效率。

GC算法

    • 标记-清除算法

这种算法首先遍历对象图并标记可到达的对象,然后扫描堆栈以寻找未标记对象并释放它们的内存。这种算法一般使用单线程工作并停止其他操作。

  • 标记-压缩算法
      有时也叫标记-清除-压缩算法,与标记-清除算法有相同的标记阶段。在第二阶段,则把标记对象复制到堆栈的新域中以便压缩堆栈。这种收集器也停止其他操作。

 

    • 复制算法

这种收算法将堆栈分为两个域,常称为半空间。每次仅使用一半的空间,jvm生成的新对象则放在另一半空间中。gc运行时,它把可到达对象复制到另一半空间,从而压缩了堆栈。这种方法适用于短生存期的对象,持续复制长生存期的对象则导致效率降低。

    • 增量算法

增量算法把堆栈分为多个域,每次仅从一个域收集垃圾。这会造成较小的应用程序中断。

    • 分代算法

这种算法把堆栈分为两个或多个域,用以存放不同寿命的对象。jvm生成的新对象一般放在其中的某个域中。过一段时间,继续存在的对象将获得使用期并转入更长寿命的域中。分代算法对不同的域使用不同的算法以优化性能。

    • 并发算法

并发算法与应用程序同时运行。这些算法在某点上(比如压缩时)一般都不得不停止其他操作以完成特定的任务,但是因为其他应用程序可进行其他的后台操作,所以中断其他处理的实际时间大大降低。

    • 并行算法

并行算法使用某种传统的算法并使用多线程并行的执行它们的工作。在多cpu机器上使用多线程技术可以显著的提高java应用程序的可扩展性。

GC流程

了解GC流程,就要先了解jvm的堆内存结构

 

如上如所示,整个堆可以分为3部分
    1. Young:
      • Eden:存放新生对象。
      • From:存放经过垃圾回收没有被清除的对象。
      • To:和From做Copying collection,位置会和From互换。
    2. Tenured Space:新域中的对象,经过了一定次数的GC循环后,被移入旧域。
    3. Permanent Space:  存储类和方法对象,从配置的角度看,这个域是独立的,不包括在JVM堆内。

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

好,现在我们来看一下gc的流程:

1. 对于新生成的对象,都放在Eden中;当Eden充满时,GC将开始工作,即所谓的Young GC,首先停止应用程序的运行,开始收集垃圾。

    • 这时,会把所有可以找到的对象放到From Space
    • 一旦From Space充满,GC会把From中可以找到的对象放到To Space
    • 一旦To Space充满,GC会把To中可以找到的对象放到From Space,并覆盖From中原有的储存对象
    • 如此交替,经过一定次数的GC操作之后,会把仍然可以找到的对象放到Tenured Space

2. 当Tenured Space(旧域)满了,便会触发一次Full GC,Full GC很消耗内存,把old,young里面大部分垃圾回收掉。这个时候用户线程都会被block。

另外,在整个过程中,有两个地方值得我们注意:
1. 对象在新域中,采用的是coping(复制)算法

原因就是大部分新生对象都是短期存在的。

前边说过,复制算法适合短生存期对象。最理想的状态是,所有移出Eden、From或者To的对象都会被收集,这样可以使要复制的对象量达到最小。如果持续复制长期存在的对象…岂不是搬来搬去瞎倒腾。

2. 对于旧域,则采用的是标记-清除-压缩算法

前边说过,Full GC很耗内存,且会block住用户进程。压缩,虽是一个耗时操作,但为了提高旧域的利用率,减少Full GC次数,是必要的。

 

引用:http://ningq.com/2010/11/talk-about-java-gc.html

oracle官方介绍:http://www.oracle.com/webfolder/technetwork/tutorials/obe/java/G1GettingStarted/index.html

 

 

 

分享到:
评论

相关推荐

    各大互联网公司常见java面试题

    GC何时对什么做什么取决于垃圾收集策略。 18. **类加载器**:双亲委派模型机制保证类加载的全局一致性,防止类的重复加载。类加载器包括Bootstrap ClassLoader、Extension ClassLoader、AppClassLoader等。 19. **...

    Java进阶教程解密JVM视频教程

    * 在垃圾回收章节,不仅会介绍垃圾回收算法、分代垃圾回收机制,还会重点介绍 G1 垃圾回收器,辨析 Full GC 发生条件,jdk8以来对垃圾回收的优化,以及垃圾回收的调优法则。 * 在字节码与类加载技术章节,会从一个 ...

    java后端,2024届面试经验(最新最全的阿里系宝典)

    #### 二、聊实习项目(12分钟) - **知识点3:跨语言平台理解** - 理解管理平台底层C++与服务层Java的协作机制,了解不同语言间的接口设计原则。 - **示例问题**:“接口的返回侧实现了backup重传?”考察对接口...

    万得信息技术Java开发面经.pdf

    万得信息技术Java开发⾯经 上周⾯试发⽣了件很遗憾的事,周⼆收到万得的⾯试邀请,周三⾯试(⾯了50mins),周五hr电话通知我⾯试通过,跟我聊了⼀些个⼈情 况以及薪资待遇,让我准备好下周的定薪考核(可以选择线上...

    理解JAVA虚拟机-内存管理、垃圾收集器.pptx

    Java虚拟机(JVM)是Java程序运行的核心,它负责管理程序的内存,包括内存的分配、使用和回收。在深入理解JVM内存管理和垃圾收集器之前,我们需要先了解JVM内存模型的基本结构。 内存模型主要包括以下几个部分: 1...

    java8源码-nettychat:注册,登录,单聊,群聊,添加好友,创建群组,离线消息,消息推送,异步任务处理等等

    gc以及eden会内存溢出 // nohup java -Xms300M -Xmx300M -jar server-1.0-jar-with-dependencies.jar > /data/log/chat.log & 5. nohup java -jar server-1.0-jar-with-dependencies.jar > /data/log

    JVM内存管理面试常见问题全解.doc

    十一、聊聊 Java 的 GC 机制 Java 的 GC 机制是 Java 的垃圾回收机制,GC 机制的目的是释放垃圾对象的内存。GC 机制包括垃圾回收器、垃圾回收算法和垃圾回收的频率等。 十二、CMS 和 G1 的区别 CMS 和 G1 是 Java...

    linux jdk 1.8 64位

    - 垃圾回收(GC)策略:Java 8提供了不同的垃圾回收器,如G1、Parallel GC等,可以根据应用需求调整。 - JMX(Java Management Extensions):用于远程监控和管理Java应用程序。 5. **安全**: - Java 8的安全性...

    curso-springboot2-java-11

    1. **性能提升**:Java 11 的优化为 Spring Boot 应用提供了更好的性能基础,例如 ZGC 可以降低 GC 延迟。 2. **模块化开发**:Java 11 的模块系统可以与 Spring Boot 结合,帮助组织和管理大型 Spring 应用的结构...

    JVM 面试题总结.md

    ### 聊一聊JVM中的垃圾回收算法? JVM中的垃圾回收算法主要包括: 1. **标记-清除算法**:分为“标记”和“清除”两个阶段。标记阶段标记出所有需要回收的对象,清除阶段则回收被标记的对象占用的空间。这种算法的...

    hornet:Hornet,为低延迟应用程序优化的JVM

    基于的增量GC,暂停时间非常短。 执行引擎: 快速口译员基于DynASM的基准编译器优化基于LLVM的编译器OpenJDK类库支持Linux和Darwin 用C ++ 11编写设计是类似java的前端。 是一种字节码转换器,由快速解释器和两个...

    超级课程表的技术选型

    超级课程表是一款面向大学生群体的应用程序,旨在提供便捷的课程管理、查询服务,并逐渐拓展到社交功能,如“下课聊”等。面对庞大的用户基数(1000万+注册用户)、覆盖范围广(全国3300多所高校)以及高频度的使用...

    面经:亿联网络(yealink)

    总体感受:  感觉面试非常标准,面试官问的题目多...3.JVM内存划分以及GC算法 4.聊一下mysql索引和优化 5.PreparedStatement使用两次,需要两次close()吗? 6.反问环节 其他记不清了,期待有下文 作者:wusimin432503

    iguanodon

    GC暂停(数量和总持续时间) 内存分配率 设置 $ git submodule init $ git submodule update $ cd spring-petclinic-rest $ ./mvnw install $ brew install k6 $ brew install jq 如果还没有也应该安装它。 要...

    美团.2021最新面经.pdf.zip

    什么情况下发⽣的Full GC? 2、分布式事务讲㇐下?结合项⽬想讲的可靠消息㇐致性实现⽅案 + 最⼤努⼒送达通知⽅ 案,最后也提到了单应⽤多DB(JPA)、TCC事务以及适⽤场景。 3、ES是如何调优的?副本机制作⽤?写⼊...

Global site tag (gtag.js) - Google Analytics