JVM总结

一、对象内存布局

二、JVM内存结构

2.1 程序计数器

线程私有,是一个指针,每个命令都有行号,使用程序计数器记录命令执行到多少行,记录代码执行的位置

2.2 java虚拟机栈

线程私有,开启一个线程都会开启一个虚拟机栈,默认大小为1M,加载本地方法

2.3 本地方法栈

线程私有,与虚拟机栈类似,不过加载的是native修饰的方法

2.4 堆

线程共享,存放对象,new的对象

2.5 元空间

线程共享,存储类的信息,方法的定义,静态变量,常量池放在元空间内

java虚拟机中只存在一个堆,一个元空间,在JVM启动时创建,关闭时销毁

栈、本地方法栈、程序计数器,随线程创建而创建,随线程结束死亡

三、堆内存结构

四、GC垃圾回收

发现垃圾

  1. 引用计数算法,优点:快,缺点:无法检测出循环引用
  2. 根搜索算法:从节点GCROOT开始,寻找对应的引用节点,往下依次寻找对应的引用节点,所有引用节点寻找完毕后,剩余节点被当做垃圾处理

可作为GCRoot的对象:

  1. java虚拟机栈引用的对象
  2. 本地方法栈引用的对象
  3. 元空间中静态属性引用的对象
  4. 元空间中常量引用的对象

回收垃圾

  1. 标记-清除算法:标记需要回收的对象,统一清除。
    缺点:清除后会产生大量不连续的内存碎片
  2. 标记-整理算法:标记后将所有存活对象都移动到一端,移动过程中清理可回收对象
    优点:内存整理后不会产生大量不连续的内存碎片
    缺点:耗时耗力
  3. 复制算法:将可用内存按容量分成大小相等的两块,每次只使用其中一块,当这块内存使用完,就将存活的对象复制到另一块内存,然后把使用过的内存空间清理掉。
    缺点:可使用内存少
  4. 分代收集算法:根据对象存活周期的不同将内存划分为年轻代、老年代,不同生命周期的对象可以采取不同 的回收算法,以便提高回收效率。

(1)年轻代

新生对象会放在年轻代

新生代内存按照8:1:1比例分为一个eden区和两个Survivor区
特殊情况 :当存放到Eden区的对象太大时,会直接存放到老年区,若老年区也满了,触发FullGC,年轻代和老年代全部回收

新生代发生的GC叫做MinorGC,发生频率较高

(2)老年代

当年轻代中经历了N次垃圾回收仍存活的对象放入老年代,默认15次

内存大概是年轻代的2倍,老年代满时触发MajorGC即FullGC

FullGC发生频率低,老年代对象存活时间较长,存活率较高。

(3)元空间-持久代

存放静态文件,如Java类、方法等,存储到元数据区

五、JVM调优参数

-Xms8g :设置 JVM中堆初始大小(s size)为8g,可设置与-Xmx相同,避免垃圾回收完成重新分配内存

-Xmx8g :设置堆最大(x mix)可用内存为8G

-Xmn4g :设置年轻代(n)大小为4G

-XX:MaxMetaspaceSize=128m: 设置元空间最大为为128m ,

-XX:MetaspaceSize=128m 用于设置元空间的初始大小, 默认值约21M

相关推荐
宸丶一17 小时前
Day 13:持久化记忆 - 让 Agent 拥有长期记忆
jvm·python·ai
cfm_291419 小时前
JVM新一代垃圾收集器深度解析:G1与ZGC
java·jvm
顺风尿一寸1 天前
JVM 字段布局揭秘:Best‑Fit 算法如何为每个字段精准分配偏移量
jvm
小bo波1 天前
Java反射机制——运行时"透视"类的秘密
java·jvm·反射·源码分析·动态代理·进阶·spring底层·框架原理
程序猿阿伟1 天前
《拆解Chrome存储架构:浏览痕迹的残留死角与清除路径》
jvm·chrome·架构
于指尖飞舞1 天前
java后端面试题(jvm极简)
java·开发语言·jvm
鹅城剑仙1 天前
JVM 内存模型与 GC 调优实战指南
jvm
Javatutouhouduan1 天前
2026年Java面试核心讲(终极版)全网首次开源!
java·jvm·java多线程·java面试·后端开发·java程序员·java八股文
程序员二叉1 天前
【JUC】线程池全套深度详解|参数|流程|拒绝策略|调优|异常处理
java·开发语言·jvm·算法·面试·juc
小马爱打代码2 天前
面试题:内存模型与垃圾回收深度解析
jvm