栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

jvm 持续更新中

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

jvm 持续更新中

jvm java虚拟机组成

类装载系统执行引擎运行时数据区
内存模型

1、堆

new出来的对象存放在堆里面年轻代(1/3占比),Eden(伊甸园去)8/10占比,servivor0 1/10占比,servivor1 1/10占比老年代(2/3占比):静态变量引用的对象、spring容器的bin对象、controller、service、线程池、对象池、缓存对象…gc roots:线程栈、方法区两部分存放的本地变量、静态变量、本地方法栈的变量。gc时将gc roots 对象作为起点,从这些节点开始向下搜索引用对象,找到的对象标记为非垃圾对象,其余未标记的对象是垃圾对象。可达性分析算法:分代年龄:对象每经历一次gc,没有清除掉分代年龄会加1,年轻代中分代年龄达到15后会将对象移动到老年代中。minor gc:Eden(伊甸园去)8/10占比内存放满后会触发minor gc,回收年轻代的垃圾对象。gc期间会发生STW stop the world,但是持续时间会很短,几乎无影响。full gc:回收年轻代和老年代整个堆的内存空间进行垃圾回收。gc期间会发生STW stop the world。暂停用户线程,待回收后才可用。jvisualvm:jvm调优的可视化工具,需要配置插件 2、方法区 3、栈(线程)

程序运行main方法后会在栈中开辟一块独立的栈空间(专属的内存区域),区分不同方法的局部变量,即栈帧内存区域。与数据结构中的栈类似,程序中方法先调用后结束。占中包含 局部变量、操作数栈、动态链接、方法出口。 4、本地方法栈 5、程序计数器 类装载系统 字节码执行引擎

负责垃圾回收 jvm调优

减少full gc分析每个对象的大小,每个对象的字节的总数*峰值的对象数量 垃圾回收算法

1、标记清除法
会产生磁盘碎片,磁盘空间不连续

2、标记复制
没有碎片,浪费空间

3、标记整理算法
没有碎片,效率偏低

垃圾收集器 1.1 新生代垃圾收集器 1.1.1 Serial 收集器

Serial 是一款用于新生代的单线程收集器,采用复制算法进行垃圾收集适用场景:Client 模式(桌面应用);单核服务器。可以用 -XX:+UserSerialGC 来选择 Serial 作为新生代收集器。 1.1.2 ParNew 收集器

ParNew 就是一个 Serial 的多线程版本通过 -XX:ParallelGCThreads 来设置垃圾收集的线程数默认开启的收集线程数和 CPU 数量一致适用场景:多核服务器 1.1.3 Parallel Scavenge 收集器

一款用于新生代的多线程收集器Parallel Scavenge 的目标是达到一个可控制的吞吐量吞吐量 = 运行用户代代码时间/(运行用户代码时间+垃圾收集时间)适用场景:注重吞吐量,高效利用 CPU,需要高效运算且不需要太多交互 1.2 老年代垃圾收集器 1.2.1 Serial Old 收集器

Serial Old 收集器是 Serial 的老年代版本,同样是一个单线程收集器,采用标记-整理算法。适用场景:Client 模式(桌面应用),单核服务器与 Parallel Scavenge 收集器搭配,作为 CMS 收集器的后备预案 1.2.2 CMS(Concurrent Mark Sweep) 收集器

以最短回收停顿时间为目标的收集器 1.2.3 Parallel Old 收集器

Parallel Scavenge 的老年代版本,是一个多线程收集器,采用标记-整理算法 GC发展阶段

Serial => Parallel (并行) => CMS(并发) => G1 => ZGC

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/785991.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号