2. JVM的架构模型和生命周期

一、前言

Java 编译器输入的指令流是一种基于栈的指令集架构 ,还有另一种指令集架构是基于寄存器的指令集架构。

二、两种架构之前的区别

基于栈的架构特点:

  • 设计和实现更简单,适用于资源受限的系统;
  • 避开了寄存器的分配难题:使用零地址指令方式分配。
  • 指令流中的指令大部分是零地址指令,其执行过程依赖于操作栈。指令集更小,编译器容易实现。
  • 不需要硬件支持,可移植性更好,更好实现跨平台。

基于寄存器的架构特点:

  • 典型的应用是x86的二进制指令集:比如传统的 PC,以及 Android 的 Davlik 虚拟机
  • 指令集架构则完全依赖于硬件,可移植性差
  • 性能优秀,执行效率高
  • 花费更少的指令完成一项操作
  • 在大部分情况下,基于寄存器架构的指令集都是以一地址指令,二地址指令,三地址指令为主。

这时候真后悔当初上学时,计算机组成原理这些大课没好好学,都是一些熟悉的名词在耳边绕,但是就是不理解他在讲什么东西。

三、JVM的生命周期

虚拟机的启动

类加载器(bootstrap class loader) 创建初始类(initial class)来完成,这个类由虚拟机的具体实现指定。

虚拟机的执行

  • 执行Java程序
  • 程序开始执行时它才运行,程序结束时他就停止
  • 执行一个Java程序,真正在执行的是一个叫Java虚拟机的进程

虚拟机的退出

  • 程序正常执行结束
  • 程序执行过程中遇到异常或者错误而异常终止
  • 由于操作系统错误导致虚拟机进程终止
  • 某些线程调用 Runtime 类或者 System 类的 exit 方法,或 Runtime 类的 halt 方法,并且 Java 安全管理器也允许这次 exit 或 halt 操作
  • JNI(Java Native Interface)规范描述了用 JNI 来加载或者卸载 Java 虚拟机时,Java 虚拟机退出情况

四、总结

通过上面的一些比较,虽然暂时还不明白底层的实现逻辑,但是先get到一点,因为不同的CPU架构,寄存器的设计是不一样的,所以不能设计为基于寄存器的方式,否则无法兼容。基于栈的方式,规避了寄存器的限制,但是指令集更小,所以完成一个操作需要执行的指令就更多,自然也就导致执行效率相比于寄存器架构低。

相关推荐
Dicky-_-zhang1 小时前
消息队列Kafka/RocketMQ选型与高可用架构:从单体到100万TPS的演进
java·jvm
2301_781571421 小时前
Golang格式化输出占位符都有什么_Golang fmt占位符教程【通俗】
jvm·数据库·python
fake_ss1981 小时前
AI时代学习全栈项目开发的新范式
java·人工智能·学习·架构·个人开发·学习方法
米高梅狮子2 小时前
第2章 docker容器
运维·docker·云原生·容器·架构·kubernetes·自动化
微学AI4 小时前
Hermes Agent vs Claude Code 架构对比与创新分析
架构
沪漂阿龙4 小时前
面试题详解:检索链路设计全攻略——RAG 检索架构、查询理解、多路召回、混合检索、Rerank、上下文构造与评估闭环
大数据·人工智能·架构
Dicky-_-zhang5 小时前
容器编排实战:Docker与Kubernetes对比选型与落地实践
java·jvm
码云之上5 小时前
万星入坞·其二:子应用如何优雅地"入坞"
性能优化·架构·前端框架
Apache RocketMQ5 小时前
RocketMQ 源码解析——Controller 高可用切换架构
架构·rocketmq·java-rocketmq
数字化顾问5 小时前
(122页PPT)数字化架构的演进和治理(附下载方式)
java·运维·架构