java应用开发之JVM运行时内存分析
1.JVM的运行时内存也叫JVM堆
从GC的角度可以将JVM分为新生代,老年代,永久代。其中新生代默认占1/3的堆内存空间,老年代默认占2/3内存空间,永久代占非常少的堆内存空间方式。
而新生代分为Eden,SurvivorFrom,SurvivorTo区,Eden默认占8/10新生代区域空间,SurviorFrom和SurviorTo则占1/10.

2.JVM新创建的对象
JVM新创建的对象,除了大对象外都会放在新生代中,由于JVM会频繁创建对象,所以新生代会频繁出发MinorGC进行垃圾回收。
3.新生代详解
- Java新创建的对象先放在Eden区,如是大对象则分配到老年区。
- Eden区内存空间不足时则触发GC对新生代进行一次垃圾回收
- SurviorTo保存上一次MinorGC的幸存者
- SuviorFrom将上一次MinorGC作为这一次的扫描对象
4.老年代详解
老年代则不会频繁出发MajorGC,当MinorGC过后仍然出现老年代空间不足,则会触发MajorGC进行垃圾回收。MajorGC采用的是标记清除算法。因为要扫描老年代所有对象,所以耗时较长。
5.永久代
指的是内存永久保存区域,主要存放Class和Meta(元数据)。
以上就是java应用开发之JVM运行时内存分析的详细内容,更多关于JVM运行时内存的资料请关注脚本之家其它相关文章!
相关文章
解决IDEA中Maven依赖包导入失败报红问题(总结最有效8种解决方案)
这篇文章主要介绍了解决IDEA中Maven依赖包导入失败报红问题,本文通过图文详解给大家总结了最有效的8种解决方法,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-07-07
Spring实战之Bean定义中的SpEL表达式语言支持操作示例
这篇文章主要介绍了Spring实战之Bean定义中的SpEL表达式语言支持操作,结合实例形式分析了Bean定义中的SpEL表达式语言操作步骤与实现技巧,需要的朋友可以参考下2019-12-12
Spring Cache自定义缓存key和过期时间的实现代码
使用 Redis的客户端 Spring Cache时,会发现生成 key中会多出一个冒号,而且有一个空节点的存在,查看源码可知,这是因为 Spring Cache默认生成key的策略就是通过两个冒号来拼接,本文给大家介绍了Spring Cache自定义缓存key和过期时间的实现,需要的朋友可以参考下2024-05-05
Spring Boot获取resources目录下的文件三种方式详解
在Spring Boot项目中,经常需要获取resources目录下的文件,这些文件可以包括配置文件、模板文件、静态资源等,这篇文章主要介绍了Spring Boot获取resources目录下的文件的三种方式,需要的朋友可以参考下2023-06-06


最新评论