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

七、堆空间分代思想

相关推荐
曹轲恒3 分钟前
SpringBoot配置文件
java·spring boot
姓蔡小朋友8 分钟前
JVM 内存分区
jvm
亓才孓15 分钟前
[认识异常和错误]java
java·开发语言
码农水水22 分钟前
中国电网Java面试被问:流批一体架构的实现和状态管理
java·c语言·开发语言·面试·职场和发展·架构·kafka
a31582380634 分钟前
大语言模型应用开发技术要求
算法·大语言模型·应用开发
倦王36 分钟前
力扣日刷26112
算法·leetcode·职场和发展
程序员清风41 分钟前
猿辅导二面:线上出现的OOM是如何排查的?
java·后端·面试
yaoxin5211231 小时前
291. Java Stream API - 从正则表达式创建 Stream
java·开发语言