JVM内存区域解析

简介: “原创精选,转载注明出处,三克油”@Date 2017.05.24概念介绍(基于JDK7)堆(分代收集算法)年轻代(Minor GC)Eden区存储新对象或者生命周期很短的对象From Survivor区Eden...

“原创精选,转载注明出处,三克油”
@Date 2017.05.24

概念介绍(基于JDK7)

  • 堆(分代收集算法)

    1. 年轻代(Minor GC)
      • Eden区
        • 存储新对象或者生命周期很短的对象
      • From Survivor区
        • Eden区的垃圾回收仍能存活下来的依旧存在引用的对象会待在这个区域
      • To Survivor区
        • Eden区的垃圾回收仍能存活下来的依旧存在引用的对象会待在这个区域
    2. 年老代
      • Eden区和Survivor区的多次GC后仍然存活下来的对象 - major GC
      • 内存大小为-Xmx对应的值减去-Xmn对应的值
      • 新建的对象也有可能直接进入老年代
        1. 大对象:可通过启动参数设置-XX:PretenureSizeThreshold超过则直接在老年代分配
        2. 大的数组对象,且数组中无引用外部对象
  • 方法区(Non-Heap(非堆))

    1. 永久代(HotSpot VM)
      • 各个线程共享的内存区域
      • 方法区是线程安全的
      • 存储已被虚拟机加载的类信息、方法(数据及代码)、常量、静态变量、即时编译器编译后的代码等数据
      • 在Java8里已被废除了,被元空间取代
    2. 运行时常量池(Runtime Constant Pool)
      • 存放编译期生成的各种字面量和符号引用
      • 运行期间也可能将新的常量放入池中
      • String类的intern()方法
    1. 虚拟机栈
      • 方法执行的内存模型
      • 每个线程都有自己专属的栈,这个栈是别的线程无法访问的
      • 生命周期与线程相同
      • 存储局部变量表(存放方法参数和方法内部定义的局部变量)、操作栈、动态链接、方法出口、方法调用的中间结果及返回地址
      • 线程请求的栈深度大于虚拟机所允许的深度,将抛出StackOverflowError异常
      • 虚拟机栈可动态扩展,当扩展时无法申请到足够的内存时会抛出OutOfMemoryError异常
    2. 本地方法栈
      • 为虚拟机使用到的Native方法服务
  • 计数器

    1. 程序计数器
      • 分支、循环、跳转、异常处理、线程恢复
      • 每条线程都需要有一个独立的程序计数器
      • JVM执行的字节码指令地址
      • 当前线程所执行的字节码的行号指示器
      • 字节码解释器工作时就是通过改变这个计数器的值来选取下一条需要执行的字节码指令
      • 此内存区域是唯一一个在Java 虚拟机规范中没有规定任何OutOfMemoryError情况的区域
  • 直接内存(Direct Memory)

    1. NIO出现后使用
      • 本机直接内存的分配不会受到Java堆大小的限制

持久代 --> 元空间 (JDK8)

  • 元空间
    1. 本地堆内存中的一部分
    2. 达到最大阈值时进行该区域清理
    3. 类及相关的元数据的生命周期与类加载器的一致
    4. 使用-XX:MaxMetaspaceSize参数可以设置元空间的最大值
    5. 默认是没有上限的,系统内存上限是多少它就是多少
    6. 达到设定的最大值后,对于无用的类和类加载器,垃圾收集此时会触发

Error

  • 内存溢出(Out Of Memory) : 程序在申请内存时,没有足够的内存空间供其使用
  • 内存泄露(Memory Leak) : 程序在申请内存后,无法释放已申请的内存空间.一次内存泄露可以忽略,泄露堆积后果很严重,最终会导致Out Of Memory.
相关文章
|
29天前
|
Web App开发 缓存 监控
内存溢出与内存泄漏:解析与解决方案
本文深入解析内存溢出与内存泄漏的区别及成因,结合Java代码示例展示典型问题场景,剖析静态集合滥用、资源未释放等常见原因,并提供使用分析工具、优化内存配置、分批处理数据等实用解决方案,助力提升程序稳定性与性能。
505 1
|
6月前
|
Arthas 存储 算法
深入理解JVM,包含字节码文件,内存结构,垃圾回收,类的声明周期,类加载器
JVM全称是Java Virtual Machine-Java虚拟机JVM作用:本质上是一个运行在计算机上的程序,职责是运行Java字节码文件,编译为机器码交由计算机运行类的生命周期概述:类的生命周期描述了一个类加载,使用,卸载的整个过类的生命周期阶段:类的声明周期主要分为五个阶段:加载->连接->初始化->使用->卸载,其中连接中分为三个小阶段验证->准备->解析类加载器的定义:JVM提供类加载器给Java程序去获取类和接口字节码数据类加载器的作用:类加载器接受字节码文件。
557 55
|
16天前
|
弹性计算 定位技术 数据中心
阿里云服务器配置选择方法:付费类型、地域及CPU内存配置全解析
阿里云服务器怎么选?2025最新指南:就近选择地域,降低延迟;长期使用选包年包月,短期灵活选按量付费;企业选2核4G5M仅199元/年,个人选2核2G3M低至99元/年,高性价比爆款推荐,轻松上云。
85 11
|
19天前
|
存储 缓存 Java
我们来说一说 JVM 的内存模型
我是小假 期待与你的下一次相遇 ~
145 4
|
26天前
|
存储 缓存 算法
深入理解JVM《JVM内存区域详解 - 世界的基石》
Java代码从编译到执行需经javac编译为.class字节码,再由JVM加载运行。JVM内存分为线程私有(程序计数器、虚拟机栈、本地方法栈)和线程共享(堆、方法区)区域,其中堆是GC主战场,方法区在JDK 8+演变为使用本地内存的元空间,直接内存则用于提升NIO性能,但可能引发OOM。
|
2月前
|
存储 大数据 Unix
Python生成器 vs 迭代器:从内存到代码的深度解析
在Python中,处理大数据或无限序列时,迭代器与生成器可避免内存溢出。迭代器通过`__iter__`和`__next__`手动实现,控制灵活;生成器用`yield`自动实现,代码简洁、内存高效。生成器适合大文件读取、惰性计算等场景,是性能优化的关键工具。
195 2
|
7月前
|
Arthas 监控 Java
Arthas memory(查看 JVM 内存信息)
Arthas memory(查看 JVM 内存信息)
538 6
|
3月前
|
弹性计算 前端开发 NoSQL
2025最新阿里云服务器配置选择攻略:CPU、内存、带宽与系统盘全解析
本文详解2025年阿里云服务器ECS配置选择策略,涵盖CPU、内存、带宽与系统盘推荐,助你根据业务需求精准选型,提升性能与性价比。
|
3月前
|
安全 Oracle Java
JAVA高级开发必备·卓伊凡详细JDK、JRE、JVM与Java生态深度解析-形象比喻系统理解-优雅草卓伊凡
JAVA高级开发必备·卓伊凡详细JDK、JRE、JVM与Java生态深度解析-形象比喻系统理解-优雅草卓伊凡
260 0
JAVA高级开发必备·卓伊凡详细JDK、JRE、JVM与Java生态深度解析-形象比喻系统理解-优雅草卓伊凡

推荐镜像

更多
  • DNS