JVM——JVM 的内存区域是如何划分的?

Java 虚拟机运行时数据区分为方法区、堆、虚拟机栈、本地方法栈、程序计数器。

方法区(Method Area):

1\] 存储类信息、常量、静态变量和即时编译器(JIT)编译后的代码。 \[2\] 属于线程共享区域,所有线程共享方法区内存 \[3\] 在 JDK8之前,HotSpot使用永久代(PermGen)来实现方法区,JDK8之后被元空间(Metaspace)取代,元空间使用的是本地内存(Native Memory)。 堆(Heap): \[1\] 用于存放所有线程共享的对象和数组,是垃圾回收的主要区域。 虚拟机栈(JVM Stack): \[1\] 每个线程创建一个栈,用来保存局部变量、操作数栈、动态链接、方法出口信息等 \[2\] 局部变量表中存储的是基本数据类型(如int、float)以及对象引用。 \[3\] 栈是线程私有的,生命周期与线程相同。 本地方法栈(Native Method Stack): \[1\] 为本地方法服务,使用JNI(Java Native Interface)调用的本地代码在此区域分配内存。 \[2\] 和虚拟机栈类似,也是线程私有的。 程序计数器(Program Counter Register): \[1\] 是一个小的内存区域,保存当前线程执行的字节码指令的地址或行号。 \[2\] 每个线程都有一个独立的程序计数器,属于线程私有。 堆内存的进一步划分 \[1\] Eden 区:新对象最初会被分配到 Eden 区,且 Eden 区较大,频繁进行垃圾回收。 \[2\] Survivor 区:两个Survivor 区 S0 和 S1 交替使用,新对象在 Eden 区经过一次垃圾回收后存放到其中一个 Survivor区,进一步存活的对象会移动到另一个 Survivor 区,最终晋升到老年代。 \[3\] 老年代:长生命周期对象经过多次垃圾回收后会被移到老年代,MaiorGC在老年代进行,频率较低但耗时较长。

相关推荐
初学小白...1 小时前
线程同步机制及三大不安全案例
java·开发语言·jvm
凤山老林4 小时前
还在用JDK8?JDK8升级JDK11:一次价值千万的升级指南
java·开发语言·jvm·spring boot·后端·jdk
2501_938790074 小时前
详解 JVM 中的对象创建过程:类加载检查、内存分配、初始化的完整流程
jvm
宸津-代码粉碎机5 小时前
Java内部类内存泄露深度解析:原理、场景与根治方案(附GC引用链分析)
java·开发语言·jvm·人工智能·python
杨筱毅6 小时前
【底层机制】Android GC -- 为什么要有GC?GC的核心原理?理解GC的意义
android·jvm·gc
東雪木6 小时前
Java基础语言进阶学习——1,JVM内存模型(堆、栈、方法区)
java·jvm·学习
小满、13 小时前
JVM 执行引擎:字节码是如何被执行的
jvm·字节码·jvm执行引擎
无敌最俊朗@1 天前
SQLite 约束 (Constraints) 面试核心知识点
java·开发语言·jvm
milanyangbo1 天前
谁生?谁死?从引用计数到可达性分析,洞悉GC的决策逻辑
java·服务器·开发语言·jvm·后端·算法·架构
m0_748231311 天前
深入JVM:让Java性能起飞的核心原理与优化策略
java·开发语言·jvm