【Java】如何保证集合的线程安全?
【Java】线程池优点 与传统方式对比
JVM 内存区域划分
文章目录
- [JVM 内存区域划分](#JVM 内存区域划分)
1. JVM 内存区域总体架构
JVM内存区域 堆内存详细结构 方法区演进 线程共享区域 运行时数据区 线程私有区域 方法区 Method Area 堆内存 Heap 程序计数器 PC Register 虚拟机栈 JVM Stack 本地方法栈 Native Method Stack 年轻代 Young Generation Eden 区 Survivor 区 From Survivor To Survivor 老年代 Old Generation JDK 1.7: 永久代 PermGen JDK 1.8+: 元空间 Metaspace
2. 线程共享区域详解
堆内存结构 线程共享区域 Eden 区: 80% Young Generation Survivor 区: 20% From: 10% To: 10% 长期存活对象 Old Generation 大对象直接进入 存储对象实例 堆内存 Heap GC 主要管理区域 所有线程共享 存储类信息 方法区 Method Area 常量池 静态变量 JIT 编译代码 类版本/字段/方法信息 运行时常量池 字符串常量池
3. 线程私有区域详解
栈帧生命周期 线程私有区域 创建栈帧 方法调用 栈帧入栈 执行方法 栈帧出栈 方法结束 当前线程执行的字节码行号 程序计数器
PC Register 唯一没有OOM的区域 线程切换时保存执行位置 栈帧 Stack Frame 虚拟机栈
JVM Stack 局部变量表 Local Variables 操作数栈 Operand Stack 动态链接 Dynamic Linking 方法返回地址 Return Address 为Native方法服务 本地方法栈
Native Method Stack 与虚拟机栈类似
4. JVM 内存区域功能对比
JVM内存区域功能表 是否线程共享 内存区域 是否GC管理 可能异常 存储内容 线程私有 程序计数器 否 无 当前指令地址 线程私有 虚拟机栈 否 StackOverflowError
OutOfMemoryError 栈帧/局部变量 线程私有 本地方法栈 否 StackOverflowError
OutOfMemoryError Native方法信息 线程共享 堆内存 是 OutOfMemoryError 对象实例/数组 线程共享 方法区 是 OutOfMemoryError 类信息/常量/静态变量
5. 内存区域交互关系
对象创建流程 JVM内存交互 检查类加载 new 指令 分配内存 内存空间初始化 对象设置 执行init方法 方法区
存储类信息 类加载子系统 运行时常量池 虚拟机栈
方法执行 执行引擎 程序计数器
指令定位 堆内存
对象实例存储 创建对象 局部变量表
对象引用 本地方法栈
Native方法执行 本地方法接口 垃圾收集器
6. JDK 版本内存区域演进

线程共享区域:
- 堆(Heap):对象实例存储,GC主要区域
- 方法区(Method Area):类信息、常量、静态变量
- 运行时常量池:类和接口的常量
线程私有区域:
- 程序计数器(PC Register):当前指令地址
- 虚拟机栈(JVM Stack):Java方法执行
- 本地方法栈(Native Method Stack):Native方法执行
重要特点:
- 堆是最大的内存区域,被所有线程共享
- 程序计数器是唯一不会发生OOM的区域
- 虚拟机栈 和本地方法栈可能发生StackOverflowError
- JDK 8+ 使用元空间 替代永久代
- 所有区域都可能发生OutOfMemoryError(除程序计数器)
这些内存区域共同协作,支撑Java程序的运行,每个区域都有其特定的职责和生命周期管理机制。