JVM堆空间详解

一、核心概述

  • 一个JVM实例只存在一个堆内存,堆也是Java内存管理的核心区域
  • Java堆区在JVM启动的时候即被创建,空间大小同时确定,是JVM管理的最大内存空间
  • 堆内存大小可调节
  • 所有线程共享Java堆,但是可以划分线程私有缓冲区(TLAB),提升并发能力
  • 几乎所有对象实例以及数组都应当在运行时分配在堆上
  • 栈帧中保存引用,引用指向对象或数组在堆中的位置
  • 方法结束后,堆中的对象不会马上被移除,垃圾收集时才会被移除
  • 堆,是GC(Garbage Collection,垃圾收集器)执行垃圾回收的重点区域(栈没有垃圾回收)

二、内存细分

现代垃圾收集器大部分都是基于分代收集理论设计,堆空间细分为:

  • -Xms:初始内存大小
  • -Xmx:最大内存大小

三、OOM说明

工具:java visualVM

可以查看java线程,JVM参数及堆空间使用情况等信息

四、年轻代与老年代

Java堆区可以分为年轻代(YoungGen)和老年代(OldGen)

  • 年轻代可以划分为Eden空间(伊甸园)、Survivor0空间和Survivor1空间(from区、to区)

五、对象分配过程

5.1、一般过程

  • 剩余对象每次会存放到S1和S2中,空的区域
  • 只有Eden存满时会触发YoungGC,S1和S2存满时不会触发
  • 垃圾回收,频繁在新生区收集,很少在养老区收集,几乎不在永久区/元空间收集

5.2、特殊情况

1、Eden剩余空间不足以存放新对象

六、GC

6.1、GC概念

6.2、GC触发机制

七、堆空间分代思想

相关推荐
2401_8324027511 小时前
使用Scikit-learn构建你的第一个机器学习模型
jvm·数据库·python
Remember_99311 小时前
Spring 中 REST API 调用工具对比:RestTemplate vs OpenFeign
java·网络·后端·算法·spring·php
Y_0311 小时前
浅谈Java虚拟机JVM
java·开发语言·jvm
我命由我1234511 小时前
JUnit - 自定义 Rule
android·java·开发语言·数据库·junit·java-ee·android-studio
源代码•宸11 小时前
分布式理论基础——Raft算法
经验分享·分布式·后端·算法·golang·集群·raft
YiWait11 小时前
机器学习导论习题解答
人工智能·python·算法
阿杰 AJie12 小时前
使用Iterator迭代器在遍历中安全删除元素
java·spring
m0_7066532312 小时前
自动化与脚本
jvm·数据库·python
流㶡12 小时前
scikit-learn之KNN算法实战鸢尾花分类
python·算法·scikit-learn·knn
螺旋小蜗12 小时前
docker-compose文件属性(14)build
java·docker·eureka