Java虚拟机内存管理

简介: Java虚拟机内存管理

运行时数据区域(如图)


1、对各内存空间的理解

(1)程序计数器(也叫PC寄存器)Program Counter

是一块较小的内存空间,作用可以看成当前线程所执行的字节码的行号指示器

(2)Java虚拟机栈

虚拟机栈描述的是Java方法执行的内存模型:每个方法被执行的时候都会同时创建一个栈帧(方法内部执行则是栈帧内容执行)每个方法的调用直至执行完成的过程,都对应一个栈帧中虚拟机栈中的出入栈过程

该区别规定了两种异常状况:

对固定虚拟机栈大小的:StackOverFlow Error

对可动态扩展的虚拟机栈的:扩展无法申请足够的内存时,OutOfMemory Error 异常

注意:程序计数器占用的可能为CPU寄存器或操作系统内存,虚拟机栈占用的为操作系统内存,当方法执行完毕,其对应的栈帧所占内存自动释放

(3)本地方法栈

本地方法栈用于支持native方法的执行,Sun JDK即Hot Spot虚拟机是实现中的本地方法栈和虚拟机栈是同一个

(4)方法区

用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据

一定条件下会被GC(常量池的回收和对类的卸载)

内存不足引发OutOfMemory Error异常

说明:运行时常量池是方法区的一部分,一般来说,常量池除了保存Class文件中描述的符号引用外,还有把翻译出来的直接引用

(5)堆

在虚拟机启动时创建。此区域唯一目的就是存放对象的实例。几乎所有对象实例都在这里分配内存,是进行GC的主要区域

补充说明:

1)存在GC的区域有方法区(较少)和堆,但方法区较少也较难对加载的类进行卸载。堆中最多GC

2)方法区默认最小值为16MB最大值为64MB。可通过-XX:PermSize 及 -XX:MaxPermSize指定。

,在32位操作系统上最大为2GB,在64位操作系统上则没有限制,可通过 -Xmx和 -Xms设置JVM启动时申请到的堆(Heap)内存大小

最小默认情况下为物理内存的1/64,小于1GB

最大默认为物理内存的1/4小于1G

默认当空余堆内存小于40%时,JVM会增大Heap到 -Xmx指定的大小。

当空余堆内存大于70%时,JVM会减少Heap到 -Xms指定的大小。

对于运行的系统,为了避免在运行时频繁调整Heap的大小,通常将 -Xms 和 -Xmx 的值设置成一样

2、直接内存

直接内存并不是虚拟机运行时数据区的一部分,也不是Java虚拟机规范中定义的内存区域,但这部分内存也被频繁地使用,而且也导致了OutOfMemory Error异常的出现

由于JDK1.4加入了NIO类,引入了一种基于通道和缓冲区的I/O方式,它可以使用Native函数库直接分配堆外内存,然后通过一个存储在Java堆里面的DirectByteBuffer对象作为这块内存的引用进行操作(避免了Java堆和Native堆中来回复制数据。这样本机直接内存的分配不会受到Java堆大小的限制,但服务器管理员配置虚拟机的参数时,往往忽略了,这使得各个内存区域总和大于物理内存限制

目录
相关文章
|
14天前
|
监控 算法 Java
Java中的内存管理:理解Garbage Collection机制
本文将深入探讨Java编程语言中的内存管理,特别是垃圾回收(Garbage Collection, GC)机制。我们将从基础概念开始,逐步解析垃圾回收的工作原理、不同类型的垃圾回收器以及它们在实际项目中的应用。通过实际案例,读者将能更好地理解Java应用的性能调优技巧及最佳实践。
55 0
|
9天前
|
存储 缓存 Java
java线程内存模型底层实现原理
java线程内存模型底层实现原理
java线程内存模型底层实现原理
|
4天前
|
存储 算法 Java
深入解析 Java 虚拟机:内存区域、类加载与垃圾回收机制
本文介绍了 JVM 的内存区域划分、类加载过程及垃圾回收机制。内存区域包括程序计数器、堆、栈和元数据区,每个区域存储不同类型的数据。类加载过程涉及加载、验证、准备、解析和初始化五个步骤。垃圾回收机制主要在堆内存进行,通过可达性分析识别垃圾对象,并采用标记-清除、复制和标记-整理等算法进行回收。此外,还介绍了 CMS 和 G1 等垃圾回收器的特点。
14 0
深入解析 Java 虚拟机:内存区域、类加载与垃圾回收机制
|
11天前
|
Java 编译器
深入理解Java内存模型:从基础到高级
本文旨在通过通俗易懂的方式,引导读者深入理解Java内存模型(JMM)的核心概念和工作原理。我们将从简单的基础知识入手,逐步探讨重排序、顺序一致性问题以及volatile关键字的实现机制等高级主题。希望通过这篇文章,你能够对Java内存模型有一个清晰、全面的认识,并在实际编程中有效地避免并发问题。
|
8天前
|
存储 算法 Java
深入理解Java内存管理
本文将通过通俗易懂的语言,详细解析Java的内存管理机制。从JVM的内存结构入手,探讨堆、栈、方法区等区域的具体作用和原理。进一步分析垃圾回收机制及其调优方法,最后讨论内存泄漏的常见场景及防范措施。希望通过这篇文章,帮助读者更好地理解和优化Java应用的内存使用。
|
13天前
|
监控 算法 Java
Java中的内存管理与垃圾回收机制
本文将深入探讨Java编程语言中的内存管理方式,特别是垃圾回收(Garbage Collection, GC)机制。我们将了解Java虚拟机(JVM)如何自动管理内存,包括对象创建、内存分配以及不使用对象的回收过程。同时,我们还将讨论不同的垃圾回收算法及其在不同场景下的应用。
|
12天前
|
监控 算法 Java
深入理解Java中的垃圾回收机制在Java编程中,垃圾回收(Garbage Collection, GC)是一个核心概念,它自动管理内存,帮助开发者避免内存泄漏和溢出问题。本文将探讨Java中的垃圾回收机制,包括其基本原理、不同类型的垃圾收集器以及如何调优垃圾回收性能。通过深入浅出的方式,让读者对Java的垃圾回收有一个全面的认识。
本文详细介绍了Java中的垃圾回收机制,从基本原理到不同类型垃圾收集器的工作原理,再到实际调优策略。通过通俗易懂的语言和条理清晰的解释,帮助读者更好地理解和应用Java的垃圾回收技术,从而编写出更高效、稳定的Java应用程序。
|
19天前
|
监控 算法 Java
Java中的内存管理:理解垃圾回收机制的深度剖析
在Java编程语言中,内存管理是一个核心概念。本文将深入探讨Java的垃圾回收(GC)机制,解析其工作原理、重要性以及优化方法。通过本文,您不仅会了解到基础的GC知识,还将掌握如何在实际开发中高效利用这一机制。
|
19天前
|
存储 监控 算法
Java中的内存管理与垃圾回收机制解析
本文深入探讨了Java编程语言中的内存管理策略和垃圾回收机制。首先介绍了Java内存模型的基本概念,包括堆、栈以及方法区的划分和各自的功能。进一步详细阐述了垃圾回收的基本原理、常见算法(如标记-清除、复制、标记-整理等),以及如何通过JVM参数调优垃圾回收器的性能。此外,还讨论了Java 9引入的接口变化对垃圾回收的影响,以及如何通过Shenandoah等现代垃圾回收器提升应用性能。最后,提供了一些编写高效Java代码的实践建议,帮助开发者更好地理解和管理Java应用的内存使用。
|
21天前
|
存储 缓存 算法
Java中的内存管理:理解垃圾回收机制
本文将深入探讨Java中的内存管理,特别是垃圾回收机制。我们将从基本的内存分配开始,逐步解析垃圾回收的原理和过程,以及它对Java应用程序性能的影响。通过实例演示,我们会展示如何在Java中有效地管理和优化内存使用。最后,我们将讨论一些常见的内存泄漏问题及其解决方案。
下一篇
无影云桌面