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

七、堆空间分代思想

相关推荐
To_OC2 小时前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
小bo波6 小时前
使用Thread子类创建线程 VS 使用Runnable接口创建线程的区别
java·多线程·thread·并发编程·runnable
SamDeepThinking7 小时前
高并发场景下,CompletableFuture与ForkJoinPool该如何取舍?
java·后端·面试
用户938515635077 小时前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC8 小时前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥9 小时前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程
张不才10 小时前
CPU 100% 了怎么办?Java 性能排障的标准化操作
java·后端
地平线开发者10 小时前
Transformer模型部署之性能优化指南
算法
地平线开发者11 小时前
人在途中:从“编译失败”到“模型可落地”——CUDA 自定义算子
算法·自动驾驶
shepherd11111 小时前
吞吐量提升 10 倍:高并发大批量数据处理任务的架构演进与性能调优
java·后端·架构