全面理解JVM虚拟机

一、本质

虚拟机的本质是将class文件转换成操作系统具体指令。

二、JDK的类加载体系

  • 每个类加载器对加载过的类保持一个缓存。
  • 双亲委派(向上委托查找,向下委托加载)
  • 沙箱保护

打破双亲委派

  • Tomcat每个容器配置一个类加载器实现缓存隔离。
  • 通过秘钥修改Class文件(需要解密后执行)。

类和对象之间的关系

类信息存储在元数据里,对象一般存在堆中,对象指针指向元数据对应的类信息。

三、执行引擎

解释执行与编译执行

  • 解释执行:相当于同声传译。JVM接收一条指令,就将这条指令翻译成机器指令执行。
  • 编译执行:相当于提前翻译。好比领导发言前就将讲话稿翻译成对应文本,上台讲话就可以照着念,也就是JIT。(例如在HotSpot中会搜集热点代码,形成CodeCache,放到元空间中,后续执行无需编译直接就可以执行了)。
  • JDK中默认采用混合执行,它会自己检测使用哪种方式效率高,一般无需干涉。(编译执行预热慢)。
  • 编译器有C1和C2两种(默认C2),分别适用于应用端和服务端。C1编译速度快执行慢,C2相反。

静态执行与动态执行

静态执行指的是在Class文件编译过程中已经确定了执行方法,而动态执行更多关联到invokedynamic指令(函数式编程)。

四、GC垃圾回收

GC日志参考配置:

java 复制代码
-Xms60m -Xmx60m -XX:SurvivorRatio=8 -XX:+PrintGCDetails -Xloggc:./gc.log
相关推荐
ps酷教程28 分钟前
Jackson 解决没有无参构造函数的反序列化问题
java
NiceCloud喜云33 分钟前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
为思念酝酿的痛44 分钟前
POSIX信号量
linux·运维·服务器·后端
小羊在睡觉1 小时前
力扣84. 柱状图中最大的矩形
后端·算法·leetcode·golang·go
_日拱一卒2 小时前
LeetCode:994腐烂的橘子
java·数据结构·算法·leetcode·深度优先
swipe2 小时前
Neo4j + Graph RAG 医疗知识图谱工程实践:患者教育问答真正需要的是“关系可追溯”
后端·langchain·llm
隔窗听雨眠2 小时前
Nginx网关响应慢排查手记
java·服务器·nginx
智慧物业老杨2 小时前
智慧物业合同周期管理系统:从风险预警到智能交接的全流程数智化落地方案
java·人工智能·python
源码宝2 小时前
MES系统源码:Java8 + SpringBoot2.7 + MySQL8 + Redis,后端源码清爽易扩展
java·后端·源码·springboot·mes系统·源码二开·mes源码
JAVA社区3 小时前
Java高级全套教程(十)—— SpringCloudAlibaba超详细实战详解
java·开发语言·spring cloud·面试·职场和发展