JVM内存区域解析

本文涉及的产品
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: “原创精选,转载注明出处,三克油”@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.
相关文章
|
4天前
|
存储 算法 Java
深入解析 Java 虚拟机:内存区域、类加载与垃圾回收机制
本文介绍了 JVM 的内存区域划分、类加载过程及垃圾回收机制。内存区域包括程序计数器、堆、栈和元数据区,每个区域存储不同类型的数据。类加载过程涉及加载、验证、准备、解析和初始化五个步骤。垃圾回收机制主要在堆内存进行,通过可达性分析识别垃圾对象,并采用标记-清除、复制和标记-整理等算法进行回收。此外,还介绍了 CMS 和 G1 等垃圾回收器的特点。
14 0
深入解析 Java 虚拟机:内存区域、类加载与垃圾回收机制
|
19天前
|
存储 监控 算法
Java中的内存管理与垃圾回收机制解析
本文深入探讨了Java编程语言中的内存管理策略和垃圾回收机制。首先介绍了Java内存模型的基本概念,包括堆、栈以及方法区的划分和各自的功能。进一步详细阐述了垃圾回收的基本原理、常见算法(如标记-清除、复制、标记-整理等),以及如何通过JVM参数调优垃圾回收器的性能。此外,还讨论了Java 9引入的接口变化对垃圾回收的影响,以及如何通过Shenandoah等现代垃圾回收器提升应用性能。最后,提供了一些编写高效Java代码的实践建议,帮助开发者更好地理解和管理Java应用的内存使用。
|
3天前
|
存储 缓存 NoSQL
Redis 过期删除策略与内存淘汰策略的区别及常用命令解析
Redis 过期删除策略与内存淘汰策略的区别及常用命令解析
10 0
|
19天前
|
监控 算法 数据可视化
深入解析Android应用开发中的高效内存管理策略在移动应用开发领域,Android平台因其开放性和灵活性备受开发者青睐。然而,随之而来的是内存管理的复杂性,这对开发者提出了更高的要求。高效的内存管理不仅能够提升应用的性能,还能有效避免因内存泄漏导致的应用崩溃。本文将探讨Android应用开发中的内存管理问题,并提供一系列实用的优化策略,帮助开发者打造更稳定、更高效的应用。
在Android开发中,内存管理是一个绕不开的话题。良好的内存管理机制不仅可以提高应用的运行效率,还能有效预防内存泄漏和过度消耗,从而延长电池寿命并提升用户体验。本文从Android内存管理的基本原理出发,详细讨论了几种常见的内存管理技巧,包括内存泄漏的检测与修复、内存分配与回收的优化方法,以及如何通过合理的编程习惯减少内存开销。通过对这些内容的阐述,旨在为Android开发者提供一套系统化的内存优化指南,助力开发出更加流畅稳定的应用。
38 0
|
2月前
|
C# 开发者 Windows
震撼发布:全面解析WPF中的打印功能——从基础设置到高级定制,带你一步步实现直接打印文档的完整流程,让你的WPF应用程序瞬间升级,掌握这一技能,轻松应对各种打印需求,彻底告别打印难题!
【8月更文挑战第31天】打印功能在许多WPF应用中不可或缺,尤其在需要生成纸质文档时。WPF提供了强大的打印支持,通过`PrintDialog`等类简化了打印集成。本文将详细介绍如何在WPF应用中实现直接打印文档的功能,并通过具体示例代码展示其实现过程。
133 0
|
2月前
|
运维 监控 Java
【JVM 调优秘籍】实战指南:JVM 调优参数全解析,让 Java 应用程序性能飙升!
【8月更文挑战第24天】本文通过一个大型在线零售平台的例子,深入探讨了Java虚拟机(JVM)性能调优的关键技术。面对应用响应延迟的问题,文章详细介绍了几种常用的JVM参数调整策略,包括堆内存大小、年轻代配置、垃圾回收器的选择及日志记录等。通过具体实践(如设置`-Xms`, `-Xmx`, `-XX:NewRatio`, `-XX:+UseParallelGC`等),成功降低了高峰期的响应时间,提高了系统的整体性能与稳定性。案例展示了合理配置JVM参数的重要性及其对解决实际问题的有效性。
54 0
|
2月前
|
存储 编译器 C语言
【C语言篇】数据在内存中的存储(超详细)
浮点数就采⽤下⾯的规则表⽰,即指数E的真实值加上127(或1023),再将有效数字M去掉整数部分的1。
|
3月前
|
存储 分布式计算 Hadoop
HadoopCPU、内存、存储限制
【7月更文挑战第13天】
213 14
|
2月前
|
存储 监控 Docker
如何限制docker使用的cpu,内存,存储
如何限制docker使用的cpu,内存,存储
|
3月前
|
存储 固态存储 芯片
计算机中内存与存储
【7月更文挑战第28天】
42 1

推荐镜像

更多
下一篇
无影云桌面