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  // 线程栈大小
相关推荐
g***72701 小时前
解决 Tomcat 跨域问题 - Tomcat 配置静态文件和 Java Web 服务(Spring MVC Springboot)同时允许跨域
java·前端·spring
r***R2891 小时前
【spring】Spring事件监听器ApplicationListener的使用与源码分析
java·后端·spring
tkevinjd1 小时前
JavaTreeMap源码分析
java
爱笑的眼睛111 小时前
Flask应用API深度开发:从单体架构到微服务设计模式
java·人工智能·python·ai
j***12151 小时前
计算机体系结构期末复习3:GPU架构及控制流问题
java·开发语言·架构
i***t9191 小时前
Spring Cloud gateway 路由规则
java
徐老总1 小时前
mutable.Set的特性,以及自定义类中equals和hashCode方法对集合去重逻辑的影响
java
悟空码字1 小时前
Kubernetes实战:你的分布式系统“保姆”养成记
java·后端·kubernetes