JVM与Java体系结构

目录

一、Java虚拟机整体架构祥图

二、Java代码执行过程详图

三、汇编语言、机器语言、高级语言关系

四、JVM的架构模型

五、JVM的生命周期 

(一)虚拟机的启动

(二)虚拟机的执行

(三)虚拟机的退出

六、JVM发展历程

(一)sun Classic VM

(二)Exact VM

(三)hotspot虚拟机

(四)JRockit

(五)IBM J9

(六) Azul VM

(七)Liquid VM

(八)Apache Harmony

(九)TaobaoJVM

(十)Dalvik VM


一、Java虚拟机整体架构祥图

二、Java代码执行过程详图

三、汇编语言、机器语言、高级语言关系

四、JVM的架构模型

Java的编译器输入的指令流基本上是一种基于栈的指令集架构,另外一种指令集架构则是基于寄存器的指令集架构

两种架构的区别:

基于栈式架构:

1、优点

  • 设计和实现简单,适用于资源受限的系统
  • 避开了寄存器的分配难题:使用零地址指令方式分配
  • 指令流中大部分都是零地址指令,其执行过程依赖操作栈,指令集更小,编译器容易实现
    • 8位字节码,所以说指令集更小,但是完成一项操作花费的指令相对多。
  • 不需要硬件支持,可移植性更好,更好实现跨平台

2、缺点

  • 性能下降,实现同样的功能需要更多的指令,毕竟还要入栈出栈等操作

基于寄存器架构:

1、优点

  • 性能优秀,执行更高效
  • 花费更少的指令去完成一项操作

2、缺点

  • 指令集架构完全依赖硬件,可移植性差

3、典型应用是X86的二进制指令集,比如传统的PC以及安卓的Davlik虚拟机(16位字节码)

大部分情况下,指令集往往以一地址指令,二地址指令和三地址指令为主。

为什么说栈式花费的指令多?

我们可以通过javap命令反编译一个文件,查看其计算流程:

javap 查看字节码

  • -v输出附加信息
  • -l输出行号和本地变量表
  • -p显示所有类和成员
  • -c对代码进行反汇编

五、JVM的生命周期 

(一)虚拟机的启动

通过引导类加载器bootstrap class loader创建一个初始类来完成的,这个类是由虚拟机的具体实现指定的。

(二)虚拟机的执行

执行一个所谓的Java程序的时候,真正执行的是一个叫Java虚拟机的进程

(三)虚拟机的退出

  • 程序正常执行结束
  • 执行过程遇到异常或错误而异常终止
  • 操作系统错误导致Java虚拟机进程终止
  • Runtime类或System类的exit方法、runtime类的halt方法,并且Java安全管理器允许这次exit或halt操作
    • halt停止、停下、阻止
    • exit方法源码:static native void halt0(int status)
  • JNI(Java Native Interface)规范描述了用JNI Invocation API来加载或卸载Java虚拟机时,Java虚拟机退出的情况

六、JVM发展历程

(一)sun Classic VM

  • 世界第一款商用Java虚拟机
  • JDK1.4时被淘汰
  • 只提供了解释器
  • 如果使用JIT编译器,就需要外挂,但是JIT和解释器不能配合工作

(二)Exact VM

  • 为了解决上一个虚拟机问题,JDK1.2时,sun提供了此虚拟机
  • Exact Memory Management:准确式内存管理
    • 虚拟机知道内存中某个位置的数据是什么类型
  • 具有现代高性能虚拟机的雏形
    • 热点探测
    • 编译器与解释器混合工作模式
  • 只在Solaris平台短暂使用,其他平台还是Classic vm
    • 英雄气短,被hotspot虚拟机替换

(三)hotspot虚拟机

  • 最初由Longview  Technologies的小公司设计,1997年被sun公司收购,2009年sun公司被甲骨文收购
  • JDK1.3时,HotSpot VM成为默认虚拟机
  • 绝对市场地位,称霸武林
    • JDK6,8等均默认
  • HotSpot就是他的热点代码探测技术
    • 通过计数器找到最具编译价值代码,触发即时编译或栈上替换
    • 通过编译器与解释器协同工作,在优化响应时间和最佳执行性能中取得平

(四)JRockit

  • BEA公司
  • 专注服务器端应用
    • 不太关注程序启动速度,引起JRockit内部不包括解析器实现,全部代码靠即时编译器编译后执行
  • 世界上最快的JVM
  • 全面的Java运行时解决方案组合
    • JRockit Real Time提供毫秒或微秒级的JVM响应时间,适合财务、军事指挥,电信网络的需要
    • MissionControl服务套件,极低的开销,来监控、管理和分析生成环境中的应用程序的工具
  • 2008年BEA被oracle收购
  • JDK8中,在HOTSPOT的基础上,移植JRockit的优秀特性

(五)IBM J9

  • 全称:IBM Technology for java Virtual Machine 简称IT4J,内部代号J9
  • 市场定位与HotSpot接近,服务器端、桌面应用,嵌入式等多用途VM
  • 广泛应用于IBM的各种Java产品
    • IBM产品结合使用性能最好
  • 有影响力的三大商用虚拟机之一
  • 2017开源,OPEN J9

(六) Azul VM

  • 与特定硬件平台绑定、软硬件配合的专有虚拟机
  • 运行于Azul Systems公司的专有硬件Vega系统上的虚拟机
  • 每个实例可以管理至少数十个CPU和数百GB内存的硬件资源,并提供在巨大内存范围内实现可控的GC时间的垃圾收集器,专有硬件优化的线程调度等优秀特性
  • 2010年,发布自己的Zing JVM,可以在通用X86平台上提供接近于vega系统的特性

(七)Liquid VM

  • BEA公司开发的,运行在自家Hypervisor系统上
  • 不需要操作系统支持,本身实现了一个专用操作系统的必要功能,如线程调度、文件系统、网络支持等
  • 随着JRockit虚拟机终止开发,Liquid VM项目也停止了

 (八)Apache Harmony

  • JDK1.5,1.6兼容
  • IBM和Intel联合开发的开源JVM,2011年退役
  • Java类库代码吸纳进了Android SDK

(九)TaobaoJVM

  • 基于OpenJDK开发了自己的定制版本AlibabaJDK
  • 深度定制且开源的高性能服务器版JAVA虚拟机
  • GCIH:GC invisible heap,将生命周期较长的Java对象从heap中已到heap之外,并且GC不能管理GCIH内部的Java对象,以此达到降低GC的回收频率和提升GC的回收效率
  • GCIH中的对象还能够在多个JAVA虚拟机进程中实现共享
  • 使用crc32指令实现JVM intrinsic降低JNI的调用开销
  • 针对大数据场景的ZenGC
  • 在阿里产品上性能高,硬件严重依赖intel的CPU,损失了兼容性,但是提高了性能
  • 淘宝、天猫上线,把oracle官方JVM版本全部替换

(十)Dalvik VM

  • 谷歌开发,应用于Android系统,安卓2.2提供了JIT,发展迅猛
  • 只能称作虚拟机,不能称作Java虚拟机,没有遵循Java虚拟机规范
  • 不能直接执行Java的Class文件
  • 基于寄存器架构,不是jvm的栈架构
  • 执行的是编译后的dex文件,执行效率比较高
  • 安卓5.0使用支持提前编译AOT的ART VM替换Dalvik VM

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/154653.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

API安全之《大话:API的前世今生》

写在前面:本文结合API使用的业界现状,系统性地阐述API的基本概念、发展历史、表现形式等基础内容,主要包含以下内容: 1.什么是API 2.API的发展历史 3.现代API常用消息格式 4.top N 互联网企业API 使用现状 当前的世界是一个信…

STM32单片机智能小车一PWM方式实现小车调速和转向

目录 1. 电机模块开发 2. 让小车动起来 3. 串口控制小车方向 4. 如何进行小车PWM调速 5. PWM方式实现小车转向 1. 电机模块开发 L9110s概述 接通VCC,GND 模块电源指示灯亮, 以下资料来源官方,具体根据实际调试 IA1输入高电平&#xff…

Mac删除照片快捷键ctrl加什么 Mac电脑如何批量删除照片

Mac电脑是很多人喜欢使用的电脑,它有着优美的设计、高效的性能和丰富的功能。如果你的Mac电脑上存储了很多不需要的照片,那么你可能会想要删除它们,以节省空间和提高速度。那么,Mac删除照片快捷键ctrl加什么呢?Mac电脑…

Python爬虫实战(六)——使用代理IP批量下载高清小姐姐图片(附上完整源码)

文章目录 一、爬取目标二、实现效果三、准备工作四、代理IP4.1 代理IP是什么?4.2 代理IP的好处?4.3 获取代理IP4.4 Python获取代理IP 五、代理实战5.1 导入模块5.2 设置翻页5.3 获取图片链接5.4 下载图片5.5 调用主函数5.6 完整源码5.7 免费代理不够用怎…

【2021ICPC沈阳】EFBJHL

不知道为什么感觉以前的场要比现在的简单一点,虽然这场VP虽然题数到了但是还是差点罚时.... 现在的有些场感觉连签到都要签半天,比如前几天的ICPC西安和CCPC桂林,看了下题都不简单 这场甚至银牌题都没什么思维,只需要算法的板子…

【OpenCV实现图像找到轮廓的不同特征,就像面积,周长,质心,边界框等等。】

文章目录 概要图像矩凸包边界矩形 概要 OpenCV是一个流行的计算机视觉库,它提供了许多图像处理和分析功能,其中包括查找图像中物体的轮廓。通过查找轮廓,可以提取许多有用的特征,如面积、周长、质心、边界框等。 以下是几种使用…

【3D 图像分割】基于 Pytorch 的 VNet 3D 图像分割7(数据预处理)

在上一节:【3D 图像分割】基于 Pytorch 的 VNet 3D 图像分割6(数据预处理) 中,我们已经得到了与mhd图像同seriesUID名称的mask nrrd数据文件了,可以说是一一对应了。 并且,mask的文件,还根据结…

FANUC机器人PRIO-621和PRIO-622设备和控制器没有运行故障处理

FANUC机器人PRIO-621和PRIO-622设备和控制器没有运行故障处理 如下图所示,新的机器人开机后提示报警: PRIO-621 设备没有运行 PRIO-622 控制器没有运行 我们首先查看下手册上的报警代码说明,如下图所示, 如下图所示&#xff0c…

DSP 开发例程(5): tcp_server

目录 DSP 开发例程(5): tcp_server创建工程源码编辑tcp_echo.chelloWorld.c 调试说明 DSP 开发例程(5): tcp_server 此例程实现在 EVM6678L 开发板上创建 TCP Server进程, 完成计算机与开发板之间的 TCP/IP 通信. 例程源码可从我的 gitee 仓库上克隆或下载. 点击 DSP 开发教程…

IDEA MyBatisX插件介绍

一、前言 前几年写代码的时候,要一键生成DAO、XML、Entity基础代码会采用第三方工具,比如mybatis-generator-gui等,现在IDEA或Eclipse都有对应的插件,像IDEA中MyBatisX就是一个比较好用的插件。 二、MyBatisX安装配置使用 MyBa…

【UE 模型描边】UE5中给模型描边 数字孪生 智慧城市领域 提供资源下载

目录 0 引言1 Soft Outlines1.1 虚幻商城1.2 使用步骤 2 Auto Mesh Outlines2.1 虚幻商城2.2 使用步骤 3 Survivor Vision3.1 虚幻商城3.2 使用步骤 结尾 🙋‍♂️ 作者:海码007📜 专栏:UE虚幻引擎专栏💥 标题&#xf…

大数据-Storm流式框架(三)--Storm搭建教程

一、两种搭建方式 1、storm单节点搭建 2、完全分布式搭建 二、storm单节点搭建 准备 下载地址:Index of /dist/storm 1、环境准备: Java 6 Python 2.6.6 2、上传、解压安装包 3、在storm目录中创建logs目录 mkdir logs 启动 ./storm help …