首页 > 其他分享 >JVM&GC-通用术语

JVM&GC-通用术语

时间:2022-09-20 15:33:25浏览次数:68  
标签:术语 G1 对象 Region GC 内存 JVM 垃圾

G1(Garbage First)

G1是一个并行回收器,他把内存分割为很多不相关的区间(Region),每个区间可以属于老年代或者年轻代,并且每个年代区间可以是物理上不连续的。垃圾回收时都是需要停下应用程序,不然没有办法防止应用程序的干扰,然后G1 GC可以集中精力在垃圾最多的区间上,并且只费一点点时间就可以清空这些区间里的垃圾,腾出完全空闲的区间。由于这种方式的侧重点在于处理垃圾最多的区间,所以我们给G1取一个名字:垃圾优先(Garbage First).
G1内部主要有四个操作阶段:

  • 年轻代回收(A Young Collection)
  • 运行在后台的并行循环(A Background Concurrent Cycle)
  • 混合回收(A Mixed Collection)
  • 全量回收(Full GC)

java对象头

在HotSpot虚拟机中,对象在内存中的布局可以分为:对象头,实例数据,对齐填充三部分。
对象头:只要包括对象自身的运行行元数据,比如哈希码,GC分代年龄,锁状态标志,同事还包含一个类型指针,指向类元数据,表明该对象所属的类型。
实例数据:对象真正存储的有效信息,包括程序代码中定义的各种类型的字段(包括从父类继承下来的和本身拥有的字段)。
对齐填充:他不是必要存在的,仅仅起着占位符的作用。

HotSpot

和其他虚拟机一样,Hotspot虚拟机为字节码提供一个运行时环境。
Hotspot主要负责以下三件事情:

  • 执行方法所请求的指令和运算。
  • 定位、加载和验证新的类型(即加载类)。
  • 管理应用内存,包括堆栈方法区等。

枚举根节点

可作为GC Roots的节点主要是在全局性的引用(例如常量或静态类属性)与执行上下文(例如栈帧中的本地变量表)中。

堆内存快照(java Heap Dump)

Java Heap是分配给实例类和数组对象运行的数据区,所有Java线程在运行期间共享Heap中的数据。Java Heap Dump相当于java应用在运行的时候在某个时间点上打了个快照(SnapShot)。

根集合

简单的讲就是栈里面的对象引用和堆内存里面的对象的集合。从这些对象开始就可以一级一级的追踪到所有存活的对象。

永久区(PermGen Space)

PermGen Space的全称是PermGen Generation Space 是指内存中永久保存的区域。这一部分用于存放Class和Meta的信息,Class在被加载的时候被放入PermGen Space区域。GC不会在主程序运行期间对PermGen Space进行清理。
Jdk8 Hotspot VM 开始使用本地化的内存空间来存放类的元数据,这个空间叫做元空间(Metaspace)。也就是说JDK8完成了对永久区的移除。

Stop the World

Stop the World简称STW,指的是GC事件发生过程中停止所有的应用程序线程的执行。
为了让垃圾回收器可以正常且高效的执行,大部分情况下会要求系统进入一个停顿的状态。只有这样,系统中才不会有新的垃圾产生,同时停顿保证了系统状态在某一个瞬间的一致性,也有益于垃圾回收器更好的标记垃圾对象。

元空间(Metaspace)

Jdk8 Hotspot VM 开始使用本地化的内存空间来存放类的元数据,这个空间叫做元空间(Metaspace)。默认情况下,大部分类元数据都在本地内存中分配,类元数据只受可用的本地内存限制(容量取决于是32位或是64位操作系统的可用虚拟机内存大小)。

混合GC事件(Mixed GC Event)

在这个事件内部,所有的年轻代Region和一部分老年代Region一起被回收。混合GC事件是跟在Minor GC之后的,并且混合GC只有在存活对象元数据存在的情况下才会触发。

Region

G1收集器将堆进行分区,划分为一个个区域,每次收集的时候,值收集其中几个区域,以此来控制垃圾回收产生的停顿时间。这个区域就是Region。G1通过将内存空间分成区域的方式避免了内存碎片问题。

Top-at-mark-start

每个区间记录这两个TAMS指针( Top-at-mark-start),分别为prevTAMS和nextTAMS,在TAMS以上的对象是新分配的,因而被视为隐式标记。

Evacuation Failure

可以理解为提升失败(Promotion Failure)。这个异常通常发生在对象提升时发现内存空间不足。对于这个异常,一般的做法是立即扩展堆内存,但是堆内存总有一个最大值,所以GC会让一些已经拷贝成功的引用进入老年代。而对于G1 GC拷贝不成功的对象会被立即放入老年代。

Root Region Scan

这个阶段从根区间的扫描开始,标记所有可达的存活对象,由于在并行标记的执行过程中移动数据会造成应用程序暂停,所以根区间扫描这个阶段需要在下一次评估中断开始执行直到结束。

标签:术语,G1,对象,Region,GC,内存,JVM,垃圾
From: https://www.cnblogs.com/leepandar/p/16711211.html

相关文章

  • 【AGC】A/B测试场景问题
    ​背景:【A/B测详情询问】平台的AB测功能分的比较详细,如果只是需要测试icon五图的话是需要选择哪种类型,另外是否需要发邮件开通功能呢。​ 问题:开发者在创建A/B测试时......
  • 安装Nginx报错:make: *** 没有规则可以创建“default”需要的目标“build”。 停止 安
    安装nginx要先安装那四个依赖yum-yinstallgccgcc-c++autoconfautomakemake CentOS下 安装 nginx执行配置命令./configure--prefix=/opt/nginx--sbin-pa......
  • jvm之复习2
    一.JVM汇总JVM(JavaVirtualMachine,Java虚拟机)Java程序的跨平台特性主要是指字节码文件可以在任何具有Java虚拟机的计算机或者电子设备上运行,Java虚拟机中的Java解释......
  • SpringCloud框架开发
     1.是什么微服务 是一种架构模式,他提倡将单一应用程序划分一组小的服务,服务之间的相互配合、互相协调。 2.SpringCloud简介 SpringClound等于分布式微服务架构......
  • GCC编译过程
    转:https://blog.csdn.net/chen1415886044/article/details/104537547GCC编译过程:上述gcc命令其实依次执行了四步操作:1.预处理(Preprocessing)2.编译(Compilation),3.汇......
  • AGC053F ESPers
    首先这题可以转化成“最后一次两个相等之前,有多少个ESPer投过票”计数。我的想法:把序列看成-1给少的投票,+1给大的投票,相等时只能使用+1。[1xxxxx][1xxxx......
  • HK32F030MF4P6的Linux GCC工具链和VSCode开发环境
    HK32F030MF4P6简介航顺的HK32F030MF4P6,TSSOP20封装,ArmCortexM0内核,内建32MHz时钟,16KFlash,2KRAM(实际上可用的有4K).这个型号的目的应该是硬件替换STM......
  • SpringCloud学习笔记(整理)
    目录版本选择springcloud组件构建微服务Eureka服务注册与发现【停更】配置eurekaserver配置client微服务注册到server使用@LoadBalanced访问eureka上注册的服务actuator......
  • 【JVM】一、从class文件开始
    一、从class文件开始1、手撕字节码文件一个简单的Java源文件packagejvmClass;publicclassjvmClass{ privateStringname; publicStringgetName(){ retu......
  • G1GC的算法与实现 pdf
    高清扫描版下载链接:https://pan.baidu.com/s/1GO-QAbmrsxH3Qvns1JATyA点击这里获取提取码 ......