JAVA进阶之路JVM-1:jvm基本组成、java程序执行过程、java程序的跨平台、静态编译器、jvm执行方式

news2024/11/24 7:24:52

JVM基本组成

  • 当线上系统突然宕机,系统无法访问,甚至直接OOM;

  • 线上系统响应速度太慢,优化系统性能过程中发现CPU占用过高,原因也许是因为JVM的GC次数过于频繁

  • 因此,新项目上线,需要设置JVM的各种参数

JDK/JRE/JVM

  • JDK:全称"Java Development Kit",Java开发工具包,提供javac编译器,jheap,jconsole等监控工具
  • JRE:全称“Java Runtime Environment”,Java允许环境,提供Class Library核心类库+JVM
  • JVM:全称“Java Virtual Machine”,Java虚拟机,用于运行java应用程序

在这里插入图片描述

Java程序执行过程

  1. 编译:通过javac命令,调用JDK编译器,将*.java源文件编译成*.class字节码文件
  2. 执行:通过java命令,调用JVM虚拟机,执行*.class字节码文件

在这里插入图片描述

Java程序的跨平台

  • 计算机平台是什么:

    我们通常把 CPU 处理器与操作系统构成的系统架构,称为计算机平台

    现代的电子计算机是基于二进制设计实现,所以CPU仅能识别0、1这样的二进制信号,儿计算机程序的本质就是0、1之间的不同组合产生的机械指令,交给CPU执行,CPU为了能识别执行这些机器指令,就需要不同CPU架构和指令集来支持,不同的厂商,设计生产的CPU,CPU架构和指令集也是不同的

    常见的指令集主要分为:精简指令集(RISC)和负载指令集(CISC)

    • 复杂指令集(CISC):×86和×64两种CPU架构基于CISC复杂指令集,比如:intel,AMD等厂商的CPU

    • 精简指令集(RISC):ARM架构的CPU基于RISC精简指令集,比如Compaq的Alpha,HP的PA-RISC、IBM的Power PC 、Apple的M1

    在底层硬件及指令集之上,需要搭载不同的操作系统,用于支持不同的 CPU 指令集。例如: 早期的 MacOs 操作系统只支持 Power 系列的 CPU 。最新的 Macos 系统只能安装在 M1片的 CPU

    Java 是一种跨平台的编程语言,主要是为了让相同的 Java 应用程序代码,不用做任何修改,可以在不同计算机系统平台上正常运行,兼容各种主流操作系统+ CPU 指令集。

  • 跨平台的原因

    实现跨平台的原因主要有两个:

    1. 不同的平台,相同的源代码,编译的字节码是相同的,所以字节码文件可以在不同平台“通用“
    2. 不同的平台,执行字节码时,都需要各自的 JVM 虚拟机版本,用于将字节码翻译成当前平台可以执行的机器码指令

在这里插入图片描述

静态编译器

通过JDK提供的静态编译器,将Java源文件编译成字节码文件

编译过程:

  1. 语法分析:通过空格分隔出源代码中的单词,操作符,控制符等信息,将其形成token信息流,传递给语法解析器
  2. 语法分析:将token信息流按照java语法规则,组装成一颗语法树
  3. 语义分析:对语法树进行关键字使用,类型匹配,作用域等语法检查
  4. 字节码:当语法分析完成后,可以生成字节码

在这里插入图片描述

字节码

​ 当一个java源文件被编译后,就会按照JVM规范和字节码定义,产生一个class字节码文件,文件内容由10个固定部分组成


​ 前4个字节非常特殊,红色框的cafe babe是詹姆斯高斯林定义的魔法数,它的作用是标志当前文件是一个字节码文件。当JVM在进行类加载的Load阶段时,如果没有识别到该标志,就说明文件不是字节码文件或已损坏,则无法进行加载。绿色框代表当前版本号,0x34的十进制为52,是JDK8的内部版本号,代表这个字节码文件基于JDK8编译

​ 剩余部分中的每一个字节军代表一个字节码指令,由于每个指令的长度按照1个字节存储,所以每个指令被称为字节码(Bytecode),Java所有的字节码指令有200多个


​ 由于纯数字的字节码指令阅读比较困难,所以JVM在字节码指令的基础上设计了一套操作码助记符,使用特殊单词来代替对应的数字指令

例如:

0x15 ILOAD:读取int类型的局部变量

0x36 ISTORE:保存int类型的局部变量

0x60 IADD:执行两个int类型的数值加法运算

0xbb NEW: 创建对象

0xbc NEWARRAY: 创建数组

0xac IRETURN: 返回int类型结果

在这里插入图片描述

JVM执行方式

JVM以解释+编译混合模式,执行字节码文件

  1. JVM的主席那个方式以解释执行为主。执行过程中,JVM将每个字节码文件中的每个指令,通过解释器转换为当前平台可以识别的机器码,然后交给CPU执行
  2. 为了提高效率,JVM还会再运行期间,JVM会通过热点代码的统计分析,识别高频的方法调用,循环体,公共模块等,当超过阈值时,JVM会基于==JIT即使编译器(just-in-time compiler)==将热点代码转换成机器码,直接交给CPU执行,提高执行效率
    • Client模式下热点代码默认阈值为1500次,在Server模式下是10000次

  • JVM解释器:程序执行的时候,解释器首先发挥作用,省去了编译器编译时间,加快程序的执行效率
  • JIT编译器:在程序运行过程中,随着时间的推移,JIT慢慢发挥作用,把热点代码编译编译成本地代码后,以后执行相同的代码,既可直接交给CPU执行,带来更高的执行效率

在这里插入图片描述

机器在热机状态下可以承受的负载要大于冷机状态(刚启动时),弱国以热机状态时的流量进行切换,可能使处于冷机状态的服务器因无法承受浏览而假死。所以,在生产环境中发布应用,应该以分批的方式进行发布,根据机器数量划分成多个批次,每个批次的机器数大概占到整个集群的15%

​ 故障案例:某应用在线发布新版本,采用进行分批发布,发布总批数误填携程分为两批发布。如果是热机状态,正常情况下,集群中一半的机器可以勉强支撑负载流量,但由于刚启动JVM均是解释执行,还没有进行热点代码统计和JIT动态编译,导致机器启动之后,当前1/2发布成功的服务器马上全部宕机

类加载器

​ 字节码必须通过类加载器,通过加载、验证、解析等校验步骤,将字节码文件中的类,加载至JVM中的运行时数据区,才能执行字节码

在这里插入图片描述

垃圾回收器

​ JVM在运行期间,通过Garbage Collctor垃圾收集器,定期对运行时数据区进行垃圾对象的回收,从而实现了内存自动管理

JVM组成结构

​ JVM由类加载器,运行时数据区,JVM解释器,JIT即时编译器,垃圾回收器、本地方法库等部分组成

​ 由类加载器完成字节码文件的加载验证和解析,存储至运行时数据区,并由执行引擎中的解释器,完成字节码到机器码的解释执行。同时进行热点代码的统计分析,调用JIT即时编译器将字节码直接编译成机器码,提高执行效率。JVM运行期间的方法调用、数据对象统一存放至运行时数据区

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

高精度基准电压源测试方法有哪些

高精度基准电压源是一种能够产生稳定、可控的电压信号的设备,广泛应用于科学研究、工业检测和仪器仪表校准等领域。为了保证电压信号的准确性和可靠性,在使用高精度基准电压源进行测试时,需要采取一系列的测试方法和技术手段。 校准和验证是使…

软著项目推荐 深度学习 植物识别算法系统

文章目录 0 前言2 相关技术2.1 VGG-Net模型2.2 VGG-Net在植物识别的优势(1) 卷积核,池化核大小固定(2) 特征提取更全面(3) 网络训练误差收敛速度较快 3 VGG-Net的搭建3.1 Tornado简介(1) 优势(2) 关键代码 4 Inception V3 神经网络4.1 网络结构 5 开始训练5.1 数据集…

AIGC文生图及工具产品简介

AIGC,全称是人工智能生成内容(Artificial Intelligence Generated Content)是继UGC(用户生成内容),PGC(平台生成内容)后,利用人工智能技术,自动生成内容的生产…

无mac电脑生成uniapp云打包私钥证书的攻略

uniapp顾名思义是一个跨平台的开发工具,大部分uniapp的开发者,其实并没有mac电脑来开发,但是生成ios的证书,官网的教程却是需要mac电脑的,那么有没有办法无需mac电脑即可生成uniapp云打包的私钥证书呢? 下…

深入理解计算机中的程序

目录 程序的存储 程序的编译过程 各位宝宝好&#xff0c;我们这次从计算机底层来讲一下程序是如何存储&#xff0c;编译的 程序的存储 我们拿一个最简单的程序来举个例子&#xff1a; #include<stdio.h> int main() {printf("hello world");return 0; } …

吐血整理,Jmeter性能测试常见问题+解决汇总(详细)

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 1、request 请求超…

【好书推荐-第30期】开发者请注意!因果推断与机器学习,终于有人能讲明白啦!

本文目录 一、因果推断二、因果推断的前世今生三、总结四、赠书条件 今天给各位读者推荐一本好书&#xff1a;《机器学习高级实践&#xff1a;计算广告、供需预测、智能营销、动态定价》&#xff0c;好书链接。 2023年初是人工智能爆发的里程碑式的重要阶段&#xff0c;以Open…

Linux MeterSphere一站式开源持续测试平台远程访问

文章目录 前言1. 安装MeterSphere2. 本地访问MeterSphere3. 安装 cpolar内网穿透软件4. 配置MeterSphere公网访问地址5. 公网远程访问MeterSphere6. 固定MeterSphere公网地址 前言 MeterSphere 是一站式开源持续测试平台, 涵盖测试跟踪、接口测试、UI 测试和性能测试等功能&am…

C++ 红黑树插入详解

前言 在之前&#xff0c;我们学习了AVL树&#xff0c;知道了AVL树是一个平衡二叉搜索树&#xff0c;如果没学过AVL树&#xff0c;这篇文章看起来会很吃力&#xff0c;不清楚如何旋转的&#xff0c;建议可以先看AVL树的内容。 今天我们要学习的红黑树&#xff0c;他也是一颗平衡…

串口通信 HAL库+cubeMX

一.通信的基本概念 1.串行通信和并行通信 2.全双工、半双工和单工 3.针对串行通信的同步通信和异步通信 4.通信速率 二.UART配置 UART常用HAL库函数 //UART_HandleTypeDef *huart是句柄typedef struct {//初始化看前面两个就可以了USART_TypeDef *Instance; /* UART 寄存器…

软件提示vcruntime140_1.dll文件丢失解决方法,和vcruntime140_1.dll丢失原因分析

vcruntime140_1.dll是Visual C Redistributable Packages的一部分&#xff0c;它是Microsoft Visual C 2015 Update 3运行时库文件。它包含了许多C标准库函数的实现&#xff0c;这些函数在运行使用C编写的程序时会被调用。所以我们在打开运行软件时候如果计算机中的vcruntime14…

(十三)Flask之特殊装饰器详解

目录&#xff1a; Flask中用作装饰器的特殊的函数第一部分&#xff1a;before_request和after_request一、 before_request装饰器&#xff1a;二、after_request装饰器&#xff1a;三、多个before_request和after_request执行流程分析&#xff1a; 首先—理论讲解&#xff1a;然…

Java核心知识点整理大全18-笔记

Java核心知识点整理大全-笔记_希斯奎的博客-CSDN博客 Java核心知识点整理大全2-笔记_希斯奎的博客-CSDN博客 Java核心知识点整理大全3-笔记_希斯奎的博客-CSDN博客 Java核心知识点整理大全4-笔记-CSDN博客 Java核心知识点整理大全5-笔记-CSDN博客 Java核心知识点整理大全6…

沈阳陪诊系统|陪诊软件开发功能

陪诊小程序的出现它可以帮助患者或家属解决就医过程中的各种问题。根据数据显示&#xff0c;2021年中国陪诊市场规模约为36.7亿元&#xff0c;预计到2025年将达到100亿元。同时&#xff0c;在医疗行业数字化转型的大背景下&#xff0c;陪诊微信小程序作为一种创新的医疗服务模式…

ABAP: JSON 报文解析——/ui2/cl_json

1、JSON数组 报文格式如下&#xff0c;是JSON 数组类型的。 [{"I_TYPE":"V","I_BUSINESSSCOPE":"1001"},{"I_TYPE":"V","I_BUSINESSSCOPE":"1002"} ] json转换为SAP内表&#xff1a; TYP…

二 使用GPIO的复用功能 利用USART 实现printf()

参考这篇&#xff1a; STM32串口通信详解 1. 关于USART USART ( universal synchronous / asynchronous receiver /transmitter) 是一种串行通讯协议 , 允许设备通过串行端口进行数据传输&#xff0c; USART 能够以同步或者异步的方式进行工作&#xff0c;在实际的运用中&…

机器学习的复习笔记4-岭回归与多项式回归

一、岭回归 在简单的线性回归中&#xff0c;一味追求平方误差最小化&#xff0c;R2值尽可能大&#xff0c;可能会受到噪声的严重干扰。噪声&#xff0c;即偶发的错误的值。 如图&#xff0c;若为满足所有点的拟合&#xff08;虚线&#xff09;&#xff0c;表面上看R2值小&…

虚拟偶像的商业化

虚拟偶像的商业化主要通过以下几种方式实现&#xff1a; 直播与内容&#xff1a;虚拟主播在各大平台进行直播&#xff0c;提供音乐、游戏、教育等内容。收益主要包括Super Chat&#xff08;直播打赏&#xff09;、收费会员&#xff08;支付月费后成为该频道会员&#xff0c;可…

如何使用WMS仓储管理系统实现流程优化

随着企业对于物流管理的需求日益增长&#xff0c;自动化WMS仓储管理系统已经成为了现代企业的核心工具之一。通过引入信息化技术&#xff0c;我们可以实现仓库管理流程的不断调整和优化&#xff0c;从而更好地满足客户的多样化需求。 一、信息化技术的引领 在现代仓库管理中&a…

Docker和Kubernetes:区别与优势对比

在现代软件开发和部署中&#xff0c;Docker和Kubernetes是两个备受关注的技术。本文将对Docker和Kubernetes进行比较&#xff0c;探讨它们的区别和各自的优势。 引言 在过去的几年中&#xff0c;容器技术得到了迅速的发展&#xff0c;并且在现代软件交付和部署中扮演着越来越重…