JVM的内存结构

JVM内存结构概述

JVM(Java虚拟机)内存结构是Java程序运行时的核心组成部分,分为多个区域,每个区域负责不同的功能。主要分为线程共享区域线程私有区域


线程共享区域

  1. 堆(Heap)

    • 存储对象实例和数组,是垃圾回收的主要区域。
    • 分为新生代(Young Generation)和老年代(Old Generation),新生代进一步划分为Eden、Survivor0、Survivor1区。
    • 通过-Xms-Xmx参数设置初始和最大堆大小。
  2. 方法区(Method Area)

    • 存储类信息、常量、静态变量、即时编译器编译后的代码等。
    • JDK 8之前称为"永久代"(PermGen),JDK 8及之后改为"元空间"(Metaspace),使用本地内存。
    • 通过-XX:MetaspaceSize-XX:MaxMetaspaceSize调整大小。
  3. 运行时常量池(Runtime Constant Pool)

    • 方法区的一部分,存储编译期生成的字面量和符号引用。

线程私有区域

  1. 程序计数器(Program Counter Register)

    • 记录当前线程执行的字节码指令地址,线程切换后能恢复到正确位置。
    • 唯一不会抛出OutOfMemoryError的区域。
  2. 虚拟机栈(JVM Stack)

    • 存储栈帧(Frame),每个方法调用对应一个栈帧,包含局部变量表、操作数栈、动态链接和方法返回地址。
    • 栈深度超过限制会抛出StackOverflowError;动态扩展失败会抛出OutOfMemoryError
    • 通过-Xss参数设置栈大小。
  3. 本地方法栈(Native Method Stack)

    • 为Native方法服务,与虚拟机栈类似,可能抛出StackOverflowErrorOutOfMemoryError

直接内存(Direct Memory)

  • 非JVM规范定义的内存,但频繁使用(如NIO的ByteBuffer)。
  • 通过-XX:MaxDirectMemorySize设置大小,溢出时抛出OutOfMemoryError

内存参数示例

java 复制代码
// 常见JVM内存参数
-Xms256m  // 初始堆大小
-Xmx1024m // 最大堆大小
-XX:MetaspaceSize=128m  
-XX:MaxMetaspaceSize=256m  
-Xss256k  // 线程栈大小
相关推荐
彭于晏Yan7 分钟前
OkHttp 与 RestTemplate 技术选型对比
java·spring boot·后端·okhttp
金銀銅鐵18 分钟前
[Java] 如何理解 class 文件中字段的 descriptor?
java·后端
5008422 分钟前
Graph Engine 是什么,为什么需要它
java·人工智能·性能优化·ocr·wpf
未若君雅裁25 分钟前
服务雪崩、降级、熔断与服务保护
java·微服务
就叫_这个吧42 分钟前
Java实现线程间的通讯--使用synchronized关键字和JUC方式实现
java·开发语言
学习中.........1 小时前
JVM 垃圾回收核心技术、演进全景与生产调优规范
java·jvm·测试工具
小小编程路1 小时前
C++类作用域
java·jvm·c++
小江的记录本1 小时前
【Java并发编程】锁机制:volatile:JMM内存模型、可见性/禁止指令重排、内存屏障、单例模式中的应用(附《思维导图》+《面试高频考点清单》)
java·后端·python·mysql·单例模式·面试·职场和发展
zandy10111 小时前
2026嵌入式BI PaaS平台技术剖析与实现指南
java·运维·paas
这是谁的博客?1 小时前
Python 异步编程核心原理与实践深度解析
java·网络·python·协程·asyncio·异步编程