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

相关文章

MybatisPlus3.3.1整合clickhouse的过程

《MybatisPlus3.3.1整合clickhouse的过程》:本文主要介绍MybatisPlus3.3.1整合clickhouse的过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定... 前言ClickHouse是俄罗斯Yandex发布的一款数据分析型数据库支持sql语法,详情可以访问官网,

IDEA下"File is read-only"可能原因分析及"找不到或无法加载主类"的问题

《IDEA下Fileisread-only可能原因分析及找不到或无法加载主类的问题》:本文主要介绍IDEA下Fileisread-only可能原因分析及找不到或无法加载主类的问题,具有很好的参... 目录1.File is read-only”可能原因2.“找不到或无法加载主类”问题的解决总结1.File

Dubbo之SPI机制的实现原理和优势分析

《Dubbo之SPI机制的实现原理和优势分析》:本文主要介绍Dubbo之SPI机制的实现原理和优势,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Dubbo中SPI机制的实现原理和优势JDK 中的 SPI 机制解析Dubbo 中的 SPI 机制解析总结Dubbo中

C#继承之里氏替换原则分析

《C#继承之里氏替换原则分析》:本文主要介绍C#继承之里氏替换原则,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#里氏替换原则一.概念二.语法表现三.类型检查与转换总结C#里氏替换原则一.概念里氏替换原则是面向对象设计的基本原则之一:核心思想:所有引py

Java内存区域与内存溢出异常的详细探讨

《Java内存区域与内存溢出异常的详细探讨》:本文主要介绍Java内存区域与内存溢出异常的相关资料,分析异常原因并提供解决策略,如参数调整、代码优化等,帮助开发者排查内存问题,需要的朋友可以参考下... 目录一、引言二、Java 运行时数据区域(一)程序计数器(二)Java 虚拟机栈(三)本地方法栈(四)J

Spring AI 实现 STDIO和SSE MCP Server的过程详解

《SpringAI实现STDIO和SSEMCPServer的过程详解》STDIO方式是基于进程间通信,MCPClient和MCPServer运行在同一主机,主要用于本地集成、命令行工具等场景... 目录Spring AI 实现 STDIO和SSE MCP Server1.新建Spring Boot项目2.a

CentOS7增加Swap空间的两种方法

《CentOS7增加Swap空间的两种方法》当服务器物理内存不足时,增加Swap空间可以作为虚拟内存使用,帮助系统处理内存压力,本文给大家介绍了CentOS7增加Swap空间的两种方法:创建新的Swa... 目录在Centos 7上增加Swap空间的方法方法一:创建新的Swap文件(推荐)方法二:调整Sww

使用Java将实体类转换为JSON并输出到控制台的完整过程

《使用Java将实体类转换为JSON并输出到控制台的完整过程》在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用JSON格式,用Java将实体类转换为J... 在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用j

基于Go语言实现Base62编码的三种方式以及对比分析

《基于Go语言实现Base62编码的三种方式以及对比分析》Base62编码是一种在字符编码中使用62个字符的编码方式,在计算机科学中,,Go语言是一种静态类型、编译型语言,它由Google开发并开源,... 目录一、标准库现状与解决方案1. 标准库对比表2. 解决方案完整实现代码(含边界处理)二、关键实现细

java变量内存中存储的使用方式

《java变量内存中存储的使用方式》:本文主要介绍java变量内存中存储的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍2、变量的定义3、 变量的类型4、 变量的作用域5、 内存中的存储方式总结1、介绍在 Java 中,变量是用于存储程序中数据