JDK8中JVM堆内存划分

简介:  一:JVM中内存JVM中内存通常划分为两个部分,分别为堆内存与栈内存,栈内存主要用执行线程方法存放本地临时变量与线程中方法执行时候需要的引用对象地址。JVM所有的对象信息都存放在堆内存中,相比栈内存,堆内存可以所大的多,所以JVM一直通过对堆内存划分不同的功能区块实现对堆内存中对象管理。

 一:JVM中内存

JVM中内存通常划分为两个部分,分别为堆内存与栈内存,栈内存主要用执行线程方法

存放本地临时变量与线程中方法执行时候需要的引用对象地址。JVM所有的对象信息都

存放在堆内存中,相比栈内存,堆内存可以所大的多,所以JVM一直通过对堆内存划分

不同的功能区块实现对堆内存中对象管理。

堆内存不够最常见的错误就是OOM(OutOfMemoryError)

栈内存溢出最常见的错误就是StackOverflowError,程序有递归调用时候最容易发生

 

二:堆内存划分

在JDK7以及其前期的JDK版本中,堆内存通常被分为三块区域Nursery内存(young 

generation)、长时内存(old generation)、永久内存(Permanent Generation for 

VM Matedata),显示如下图:


其中最上一层是Nursery内存,一个对象被创建以后首先被放到Nursery中的Eden内

存中,如果存活期超两个Survivor之后就会被转移到长时内存中(Old Generation)中

永久内存中存放着对象的方法、变量等元数据信息。通过如果永久内存不够,我们

就会得到如下错误:

java.lang.OutOfMemoryError: PermGen

而在JDK8中情况发生了明显的变化,就是一般情况下你都不会得到这个错误,原因

在于JDK8中把存放元数据中的永久内存从堆内存中移到了本地内存(native memory)

中,JDK8中JVM堆内存结构就变成了如下:


这样永久内存就不再占用堆内存,它可以通过自动增长来避免JDK7以及前期版本中

常见的永久内存错误(java.lang.OutOfMemoryError: PermGen),也许这个就是你的

JDK升级到JDK8的理由之一吧。当然JDK8也提供了一个新的设置Matespace内存

大小的参数,通过这个参数可以设置Matespace内存大小,这样我们可以根据自己

项目的实际情况,避免过度浪费本地内存,达到有效利用。


-XX:MaxMetaspaceSize=128m 设置最大的元内存空间128兆


注意:如果不设置JVM将会根据一定的策略自动增加本地元内存空间。

如果你设置的元内存空间过小,你的应用程序可能得到以下错误:

java.lang.OutOfMemoryError: Metadata space

目录
相关文章
|
1月前
|
存储 算法 Java
散列表的数据结构以及对象在JVM堆中的存储过程
本文介绍了散列表的基本概念及其在JVM中的应用,详细讲解了散列表的结构、对象存储过程、Hashtable的扩容机制及与HashMap的区别。通过实例和图解,帮助读者理解散列表的工作原理和优化策略。
38 1
散列表的数据结构以及对象在JVM堆中的存储过程
|
17天前
|
缓存 Prometheus 监控
Elasticsearch集群JVM调优设置合适的堆内存大小
Elasticsearch集群JVM调优设置合适的堆内存大小
150 1
|
29天前
|
监控 Oracle Java
JDK 21中的分代ZGC:一场内存管理的革命
JDK 21引入了分代ZGC,为Java应用程序的内存管理带来了革命性的进步。分代ZGC通过将堆内存划分为年轻代和老年代,采用并发处理和染色指针技术,实现了高吞吐量、低延迟和更好的可扩展性。这一特性显著提升了系统的性能和稳定性。
143 51
|
7天前
|
存储 监控 算法
深入探索Java虚拟机(JVM)的内存管理机制
本文旨在为读者提供对Java虚拟机(JVM)内存管理机制的深入理解。通过详细解析JVM的内存结构、垃圾回收算法以及性能优化策略,本文不仅揭示了Java程序高效运行背后的原理,还为开发者提供了优化应用程序性能的实用技巧。不同于常规摘要仅概述文章大意,本文摘要将简要介绍JVM内存管理的关键点,为读者提供一个清晰的学习路线图。
|
13天前
|
Oracle 安全 Java
深入理解Java生态:JDK与JVM的区分与协作
Java作为一种广泛使用的编程语言,其生态中有两个核心组件:JDK(Java Development Kit)和JVM(Java Virtual Machine)。本文将深入探讨这两个组件的区别、联系以及它们在Java开发和运行中的作用。
35 1
|
13天前
|
Java 编译器 API
深入解析:JDK与JVM的区别及联系
在Java开发和运行环境中,JDK(Java Development Kit)和JVM(Java Virtual Machine)是两个核心概念,它们在Java程序的开发、编译和运行过程中扮演着不同的角色。本文将深入解析JDK与JVM的区别及其内在联系,为Java开发者提供清晰的技术干货。
21 1
|
16天前
|
Java
JVM内存参数
-Xmx[]:堆空间最大内存 -Xms[]:堆空间最小内存,一般设置成跟堆空间最大内存一样的 -Xmn[]:新生代的最大内存 -xx[use 垃圾回收器名称]:指定垃圾回收器 -xss:设置单个线程栈大小 一般设堆空间为最大可用物理地址的百分之80
|
16天前
|
存储 监控 Java
合理设置JVM堆大小
合理设置JVM堆大小
19 4
|
17天前
|
Java
JVM运行时数据区(内存结构)
1)虚拟机栈:每次调用方法都会在虚拟机栈中产生一个栈帧,每个栈帧中都有方法的参数、局部变量、方法出口等信息,方法执行完毕后释放栈帧 (2)本地方法栈:为native修饰的本地方法提供的空间,在HotSpot中与虚拟机合二为一 (3)程序计数器:保存指令执行的地址,方便线程切回后能继续执行代码
18 3
|
17天前
|
存储 缓存 监控
Elasticsearch集群JVM调优堆外内存
Elasticsearch集群JVM调优堆外内存
42 1