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的堆内存结构
- Young:
- Eden:存放新生对象。
- From:存放经过垃圾回收没有被清除的对象。
- To:和From做Copying collection,位置会和From互换。
- Tenured Space:新域中的对象,经过了一定次数的GC循环后,被移入旧域。
- 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次数,是必要的。
相关推荐
而当GC运行时,可能会发送一个特殊的Win32消息`WM_GC_NOTIFY`到应用程序,通知其内存状态的变化。`GetGCMemMessage`方法就是用来检查系统消息队列中是否有这个特定的内存通知消息。 在WPF应用中,由于UI线程需要...
官方网站〜贡献网站 :backhand_index_...对于开发人员搭建环境首先按照的说明安装Jekyll及其依赖项我们建议您在此之后更新Ruby Gems和捆绑程序: gem update --systembundle update --bundler 克隆存储库git clone ...
这是我学习Java的知识总结。我会按照下面的技术思维引导图一步步完善整个整个栈知识架构。希望分享给正在学习Java的你们,可以少走一些弯路,找到进阶的...从JVM直到类加载器聊聊JVM中的垃圾回收(GC)OOM怎么办,教你
十一、聊聊 Java 的 GC 机制 Java 的 GC 机制是 Java 的垃圾回收机制,GC 机制的目的是释放垃圾对象的内存。GC 机制包括垃圾回收器、垃圾回收算法和垃圾回收的频率等。 十二、CMS 和 G1 的区别 CMS 和 G1 是 Java...
科普篇:聊聊转向系统 空气悬挂简介 轮胎的故事 轮胎数字化模型 浅聊发动机悬置系统的设计 浅谈汽车轮胎纹路 橡胶隔振设计指导 三、车身内外饰 保险杠开发 车门外把手 冲压基础知识培训 内外饰常用成型工艺 汽车...
聊聊 binlog 日志;如何实现 MySQL 读写分离? * MySQL 针对大数据量级的分库分表?对数据库如何垂直和水平拆分? * 项目中 MySQL 中 IOPS 的数量? * 事务的 4 种隔离级别; - 读未提交、读已提交、可重复读、串行 ...
超级课程表是一款面向大学生群体的应用程序,旨在提供便捷的课程管理、查询服务,并逐渐拓展到社交功能,如“下课聊”等。面对庞大的用户基数(1000万+注册用户)、覆盖范围广(全国3300多所高校)以及高频度的使用...
什么情况下发⽣的Full GC? 2、分布式事务讲㇐下?结合项⽬想讲的可靠消息㇐致性实现⽅案 + 最⼤努⼒送达通知⽅ 案,最后也提到了单应⽤多DB(JPA)、TCC事务以及适⽤场景。 3、ES是如何调优的?副本机制作⽤?写⼊...
万得信息技术Java开发⾯经 上周⾯试发⽣了件很遗憾的事,周⼆收到万得的⾯试邀请,周三⾯试(⾯了50mins),周五hr电话通知我⾯试通过,跟我聊了⼀些个⼈情 况以及薪资待遇,让我准备好下周的定薪考核(可以选择线上...
总体感受: 感觉面试非常标准,面试官问的题目多...3.JVM内存划分以及GC算法 4.聊一下mysql索引和优化 5.PreparedStatement使用两次,需要两次close()吗? 6.反问环节 其他记不清了,期待有下文 作者:wusimin432503
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
首先,让我们聊聊内存分配。在Go中,内存分配主要分为两种:栈分配和堆分配。小对象通常会被分配到栈上,这样可以快速地分配和释放。而大对象或者生命周期较长的对象会被分配到堆上。Go的运行时会智能地决定何时将...
GC Digital Research训练营网站 tl; dr GC数字研究员数字研究训练营的网站。 编辑 通过node get_data更新数据 通过bundle exec jekyll serve测试更改 设置(OS X和Linux) 要求 Node.js + NPM(使用LTF版本):JS...
基于的增量GC,暂停时间非常短。 执行引擎: 快速口译员基于DynASM的基准编译器优化基于LLVM的编译器OpenJDK类库支持Linux和Darwin 用C ++ 11编写设计是类似java的前端。 是一种字节码转换器,由快速解释器和两个...
在 5GS 中,用户可以多种方式接入 5GC,用户的永久标识也由 IMSI 变为 SUPI(Subscription Permanent Identifier)。SUPI 只在 3GPP 系统中使用,并在 UDM / UDR 配置。SUPI 格式可以不同,对应不同的 SUPI Type:0 ...
堆内存是垃圾收集器的主要工作区域,因此又被称为"GC堆"。 2. **虚拟机栈**:每个Java方法在执行时会有一个对应的栈帧,用于存储局部变量表、操作数栈、动态链接和方法返回地址等信息。当方法执行完毕,对应的栈帧...
### 聊一聊JVM中的垃圾回收算法? JVM中的垃圾回收算法主要包括: 1. **标记-清除算法**:分为“标记”和“清除”两个阶段。标记阶段标记出所有需要回收的对象,清除阶段则回收被标记的对象占用的空间。这种算法的...
- 垃圾回收(GC)策略:Java 8提供了不同的垃圾回收器,如G1、Parallel GC等,可以根据应用需求调整。 - JMX(Java Management Extensions):用于远程监控和管理Java应用程序。 5. **安全**: - Java 8的安全性...
GC暂停(数量和总持续时间) 内存分配率 设置 $ git submodule init $ git submodule update $ cd spring-petclinic-rest $ ./mvnw install $ brew install k6 $ brew install jq 如果还没有也应该安装它。 要...
#### 二、聊实习项目(12分钟) - **知识点3:跨语言平台理解** - 理解管理平台底层C++与服务层Java的协作机制,了解不同语言间的接口设计原则。 - **示例问题**:“接口的返回侧实现了backup重传?”考察对接口...