JVM10_堆空间之新生代老年代、内存分配过程、Minor GC(Young GC)、Major GC、Full GC、TLAB、逃逸分析

本文主要是介绍JVM10_堆空间之新生代老年代、内存分配过程、Minor GC(Young GC)、Major GC、Full GC、TLAB、逃逸分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
要想设置新生代中的比例,必须显式指定SurvivorRatio, 只是关闭自适应分配策略不管用

对象内存分配过程

在这里插入图片描述
在这里插入图片描述

图解

在这里插入图片描述
自我总结过程:
首先new的对象会放在Eden区,当Eden区满了以后会触发YoungGC(Minor GC),此时会把没有被GC的对象放到S0或者S1区,假设此时就是放到了S0区。当对象被放到S区开始,就会为这些对象分配一个age年龄计数器(当到了一定年龄对象就会被放到老年区)
当Eden区再一次满了,又触发YGC,幸存的对象会被放到S1区,而之前S0区没有被YGC的对象也会放到S1区。
如此重复,当S区中对象到了一定年龄,就会被放到老年区

当Eden区满了会触发YGC,但是S0或者S1区满了不会触发YGC,Eden区满了以后执行YGC,此时S0或S1会被动一起跟着执行YGC
在这里插入图片描述

对象内存分配的特殊情况

在这里插入图片描述
新产生的对象,如果Eden区能放下就放,放不下就先进行YGC,对新生代进行垃圾回收(新生代中没有被回收的被放到to区),看回收后是否能放下,如果还是放不下就直接放到老年代。
老年代一般比新生代空间大,老年代如果放不下,那么就触发FullGC(或者Major GC)对老年代进行垃圾回收。
如果还是放不下,那么就报OOM
当然JVM默认是有动态扩容机制的,当老年代内存不够会扩容,也可以设置为固定大小,此时放不下就OOM

在进行YGC时,S区也被动进行GC,然后对象就会被放到to区,如果to区放不下,那么就会直接晋升老年代,而不会等到age到了阈值

Minor GC(Young GC)、Major GC、Full GC

主要注意区分major GC 和 FullGC
有时候直接就叫majorGC。要问清楚是问老年代的major GC,还是整堆的full GC
在这里插入图片描述
在这里插入图片描述
Minor GC触发的STW(Stop The World)时间很短,而另外两个GC引发的STW时间很长,所以JVM优化大部分是针对MajorGC和FullGC的
在这里插入图片描述
在这里插入图片描述
堆空间分代的意义的

内存分配策略

在这里插入图片描述
在这里插入图片描述
new出来的东西肯定是放到堆空间的

TLAB

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
所以说,堆空间并不是都是共享的,每个线程都可以有一块独立的空间TLAB

JVM参数总结

在这里插入图片描述

堆并不是对象分配的唯一位置

如果一个对象只在方法中使用,没有逃逸出方法,那么就可能被分配到栈上
在这里插入图片描述

逃逸分析

判断是否发生逃逸,就看new出来的对象是否在方法外被调用
基于逃逸分析,所以我们在定义变量的时候,能使用局部变量,就不要在方法外定义
这样就会优先进行栈上分配内存,栈上分配的内存方法结束后也就直接出栈了,不会存在GC,
逃逸分析后栈上分配的优势 : 1、不存在GC 2、运行速度更快
在这里插入图片描述
在这里插入图片描述

逃逸分析,代码优化

在这里插入图片描述
标量替换
把一个聚合量替换成标量的表示形式,既然成为标量了,那么就可以放在栈帧中的局部变量表中,不需要在堆上分配,减少了GC
在这里插入图片描述
在这里插入图片描述
逃逸分析并不是很成熟,
TaobaoVM中的GCIH技术(将经常用的对象直接放到了不进行垃圾回收的区域)已经很成熟,只是增加了硬件,所以可以实现
在这里插入图片描述
HotSpot JVM中,虽然有逃逸分析,但是并没有使用栈上分配。而只是使用了标量替换,把聚合量拆解成多个标量,而标量就可以在栈上

所以最终明确,我们使用的hotspot虚拟机,对象实例都是在堆中分配

这篇关于JVM10_堆空间之新生代老年代、内存分配过程、Minor GC(Young GC)、Major GC、Full GC、TLAB、逃逸分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/888179

相关文章

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

Ubuntu如何分配​​未使用的空间

《Ubuntu如何分配​​未使用的空间》Ubuntu磁盘空间不足,实际未分配空间8.2G因LVM卷组名称格式差异(双破折号误写)导致无法扩展,确认正确卷组名后,使用lvextend和resize2fs... 目录1:原因2:操作3:报错5:解决问题:确认卷组名称​6:再次操作7:验证扩展是否成功8:问题已解

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

java中新生代和老生代的关系说明

《java中新生代和老生代的关系说明》:本文主要介绍java中新生代和老生代的关系说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、内存区域划分新生代老年代二、对象生命周期与晋升流程三、新生代与老年代的协作机制1. 跨代引用处理2. 动态年龄判定3. 空间分

解读GC日志中的各项指标用法

《解读GC日志中的各项指标用法》:本文主要介绍GC日志中的各项指标用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、基础 GC 日志格式(以 G1 为例)1. Minor GC 日志2. Full GC 日志二、关键指标解析1. GC 类型与触发原因2. 堆

Java内存分配与JVM参数详解(推荐)

《Java内存分配与JVM参数详解(推荐)》本文详解JVM内存结构与参数调整,涵盖堆分代、元空间、GC选择及优化策略,帮助开发者提升性能、避免内存泄漏,本文给大家介绍Java内存分配与JVM参数详解,... 目录引言JVM内存结构JVM参数概述堆内存分配年轻代与老年代调整堆内存大小调整年轻代与老年代比例元空

SpringBoot整合liteflow的详细过程

《SpringBoot整合liteflow的详细过程》:本文主要介绍SpringBoot整合liteflow的详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋...  liteflow 是什么? 能做什么?总之一句话:能帮你规范写代码逻辑 ,编排并解耦业务逻辑,代码

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

MySQL中的InnoDB单表访问过程

《MySQL中的InnoDB单表访问过程》:本文主要介绍MySQL中的InnoDB单表访问过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、访问类型【1】const【2】ref【3】ref_or_null【4】range【5】index【6】