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触发机制

七、堆空间分代思想

相关推荐
Grey Zeng3 小时前
Java SE 25新增特性
java·jdk·jdk新特性·jdk25
雨白4 小时前
Java 线程通信基础:interrupt、wait 和 notifyAll 详解
android·java
架构师沉默9 小时前
设计多租户 SaaS 系统,如何做到数据隔离 & 资源配额?
java·后端·架构
Java中文社群10 小时前
重要:Java25正式发布(长期支持版)!
java·后端·面试
每天进步一点_JL11 小时前
JVM 类加载:双亲委派机制
java·后端
NAGNIP11 小时前
大模型框架性能优化策略:延迟、吞吐量与成本权衡
算法
用户2986985301411 小时前
Java HTML 转 Word 完整指南
java·后端
渣哥12 小时前
原来公平锁和非公平锁差别这么大
java
渣哥12 小时前
99% 的人没搞懂:Semaphore 到底是干啥的?
java
J2K12 小时前
JDK都25了,你还没用过ZGC?那真得补补课了
java·jvm·后端