JVM内存区域解析

本文涉及的产品
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
简介: “原创精选,转载注明出处,三克油”@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.
相关文章
|
25天前
|
存储 Java 编译器
Java内存模型(JMM)深度解析####
本文深入探讨了Java内存模型(JMM)的工作原理,旨在帮助开发者理解多线程环境下并发编程的挑战与解决方案。通过剖析JVM如何管理线程间的数据可见性、原子性和有序性问题,本文将揭示synchronized关键字背后的机制,并介绍volatile关键字和final关键字在保证变量同步与不可变性方面的作用。同时,文章还将讨论现代Java并发工具类如java.util.concurrent包中的核心组件,以及它们如何简化高效并发程序的设计。无论你是初学者还是有经验的开发者,本文都将为你提供宝贵的见解,助你在Java并发编程领域更进一步。 ####
|
2月前
|
存储 安全 Java
jvm 锁的 膨胀过程?锁内存怎么变化的
【10月更文挑战第3天】在Java虚拟机(JVM)中,`synchronized`关键字用于实现同步,确保多个线程在访问共享资源时的一致性和线程安全。JVM对`synchronized`进行了优化,以适应不同的竞争场景,这种优化主要体现在锁的膨胀过程,即从偏向锁到轻量级锁,再到重量级锁的转变。下面我们将详细介绍这一过程以及锁在内存中的变化。
38 4
|
18天前
|
Arthas 监控 Java
JVM进阶调优系列(9)大厂面试官:内存溢出几种?能否现场演示一下?| 面试就那点事
本文介绍了JVM内存溢出(OOM)的四种类型:堆内存、栈内存、元数据区和直接内存溢出。每种类型通过示例代码演示了如何触发OOM,并分析了其原因。文章还提供了如何使用JVM命令工具(如jmap、jhat、GCeasy、Arthas等)分析和定位内存溢出问题的方法。最后,强调了合理设置JVM参数和及时回收内存的重要性。
|
16天前
|
Java Linux Windows
JVM内存
首先JVM内存限制于实际的最大物理内存,假设物理内存无限大的话,JVM内存的最大值跟操作系统有很大的关系。简单的说就32位处理器虽然可控内存空间有4GB,但是具体的操作系统会给一个限制,这个限制一般是2GB-3GB(一般来说Windows系统下为1.5G-2G,Linux系统下为2G-3G),而64bit以上的处理器就不会有限制。
15 1
|
2月前
|
缓存 算法 Java
JVM知识体系学习六:JVM垃圾是什么、GC常用垃圾清除算法、堆内存逻辑分区、栈上分配、对象何时进入老年代、有关老年代新生代的两个问题、常见的垃圾回收器、CMS
这篇文章详细介绍了Java虚拟机(JVM)中的垃圾回收机制,包括垃圾的定义、垃圾回收算法、堆内存的逻辑分区、对象的内存分配和回收过程,以及不同垃圾回收器的工作原理和参数设置。
72 4
JVM知识体系学习六:JVM垃圾是什么、GC常用垃圾清除算法、堆内存逻辑分区、栈上分配、对象何时进入老年代、有关老年代新生代的两个问题、常见的垃圾回收器、CMS
|
2月前
|
存储 缓存 算法
JVM核心知识点整理(内存模型),收藏再看!
JVM核心知识点整理(内存模型),收藏再看!
JVM核心知识点整理(内存模型),收藏再看!
|
2月前
|
存储 算法 Java
聊聊jvm的内存结构, 以及各种结构的作用
【10月更文挑战第27天】JVM(Java虚拟机)的内存结构主要包括程序计数器、Java虚拟机栈、本地方法栈、Java堆、方法区和运行时常量池。各部分协同工作,为Java程序提供高效稳定的内存管理和运行环境,确保程序的正常执行、数据存储和资源利用。
50 10
|
2月前
|
存储 算法 Java
Java虚拟机(JVM)的内存管理与性能优化
本文深入探讨了Java虚拟机(JVM)的内存管理机制,包括堆、栈、方法区等关键区域的功能与作用。通过分析垃圾回收算法和调优策略,旨在帮助开发者理解如何有效提升Java应用的性能。文章采用通俗易懂的语言,结合具体实例,使读者能够轻松掌握复杂的内存管理概念,并应用于实际开发中。
|
2月前
|
存储 监控 算法
Java中的内存管理与垃圾回收机制解析
本文深入探讨了Java编程语言中的内存管理方式,特别是垃圾回收机制。我们将了解Java的自动内存管理是如何工作的,它如何帮助开发者避免常见的内存泄漏问题。通过分析不同垃圾回收算法(如标记-清除、复制和标记-整理)以及JVM如何选择合适的垃圾回收策略,本文旨在帮助Java开发者更好地理解和优化应用程序的性能。
|
2月前
|
存储 监控 算法
JVM调优深度剖析:内存模型、垃圾收集、工具与实战
【10月更文挑战第9天】在Java开发领域,Java虚拟机(JVM)的性能调优是构建高性能、高并发系统不可或缺的一部分。作为一名资深架构师,深入理解JVM的内存模型、垃圾收集机制、调优工具及其实现原理,对于提升系统的整体性能和稳定性至关重要。本文将深入探讨这些内容,并提供针对单机几十万并发系统的JVM调优策略和Java代码示例。
55 2