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

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运行期间的方法调用、数据对象统一存放至运行时数据区

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

算法-技巧-中等-寻找重复数,环形链表|,||

记录一下算法题的学习13 这次代码中运用到的技巧是「Floyd 判圈算法」(又称龟兔赛跑算法),它是一个检测链表是否有环的算法 我们想象乌龟tortoise和兔子rabbit在链表上移动,乌龟爬的慢,兔子爬的快,当乌龟和…

Unity EventSystem的一些理解和使用

Unity的EventSystem是用于处理用户输入和交互的系统。它是Unity UI系统的核心组件之一,可以用于捕捉和分发各种事件,例如点击、拖拽、按键、射线等。 常用的属性和方法有以下这些: 属性: current: 获取当前的EventSystem实例。…

数据结构--->单链表

文章目录 链表链表的分类 单链表单链表的存储结构单链表主要实现的接口函数单链表尾插动态申请新节点单链表头插单链表的尾删单链表的头删在指定位置之前插入单链表查找插入 在指定位置之后插删除指定位置元素删除指定位置之后的元素顺序输出链表销毁单链表 顺序表和单链表的区…

随手写了个博客多平台发布脚本:Python自动发布文章到Wordpress

​ 引言 作为一名技术博主,提高博客发布效率是我们始终追求的目标。在这篇文章中,我将分享一个基于Python的脚本,能够实现博客多平台发布,具体来说,是自动发布文章到WordPress。通过这个简单而高效的脚本&#xff0c…

Android 单元测试初体验(二)-断言

[TOC](Android 单元测试初体验(二)-断言) 前言 当初在学校学安卓的时候,老师敢教学进度,翻到单元测试这一章节的时候提了两句,没有把单元测试当重点讲,只是说我们工作中几乎不会用到,果真在之前的几年工作当中我真的没…

人工智能与供应链行业融合:预测算法的通用化与实战化

前言 「作者主页」:雪碧有白泡泡 「个人网站」:雪碧的个人网站 让我们一起深入探索人工智能与供应链的融合,以及预测算法在实际应用中的价值!🔍🚀 文章目录 前言供应链预测算法的基本流程统计学习模型与机…

Gitea和Jenkins安装

Gitea Gitea:https://dl.gitea.com/gitea/1.21.0/ Jenkins:https://www.jenkins.io/download/ 数据库配置 可以参考官方文档-https://docs.gitea.cn/1.20/installation/database-prep,这里以MySQL作为讲解 MySQL 在数据库实例上&#xf…

LeetCode-面试题08.01 三步问题 C/C++实现 超详细思路及过程[E]

🎈归属专栏:深夜咖啡配算法 🚗个人主页:Jammingpro 🐟记录一句:摆了一个周末了,不能摆了,努力起来!! 文章目录 LeetCode-面试题08.01 三步问题🚗题…

SpringBoot : ch08 自动配置原理

前言 在现代的Java开发中,Spring Boot已经成为了一个备受欢迎的框架。它以其简化开发流程、提高效率和强大的功能而闻名,使得开发人员能够更加专注于业务逻辑的实现而不必过多地关注配置问题。 然而,你是否曾经好奇过Spring Boot是如何做到…

C++11线程以及线程同步

C11中提供的线程类std::thread,基于此类创建一个新的线程相对简单,只需要提供线程函数和线程对象即可 一.命名空间 this_thread C11 添加一个关于线程的命名空间std::this_pthread ,此命名空间中提供四个公共的成员函数; 1.1 get_id() 调用命名空间s…

识别验证码

背景 需求是要爬取某网站的数据, 已有账号密码, 但这个网站需要登录, 登录需要输入验证码 验证码样式如下 调研了Tesseract框架, 识别效果不佳. 后来使用ddddocr, 能正确识别. https://github.com/sml2h3/ddddocr 代码如下 def ocr():response requests.get(http://xxx/get…

【JavaScript】封装自己的JavaScript公共工具函数,并上传到npm中 进行下载

js公共方法封装方式都有哪些 全局函数 function greet(name) {console.log("Hello, " name "!"); }greet("Alice"); // 调用全局函数对象字面量 var utils {add: function(a, b) {return a b;},subtract: function(a, b) {return a - b;}…

使用opencv实现图片相似度检测

1.为什么学这个,我对图像处理非常感兴趣,我联想到海尔的指纹识别门锁是如何进行检测的,我在想不应该呀,单片机性能这么差,应该是使用了训练后的数据去检测图片的,如果我要实现草莓检测,知道它是不是草莓,我觉得单纯使用图片处理是不够的,我考虑过使用指纹模块来接触草莓从而实现…

芯片制程中温度的几种表示方法

在众多影响芯片制程的因素中,温度控制被视为一项至关重要的技术。温度是比较一种物质相对于另一种物质是冷还是热的衡量标准,它会影响到芯片的性能、可靠性以及最终产量。在不同的制程步骤中,温度扮演着各种各样的角色。但是在评价制程温度高…

振弦式轴力计和振弦采集仪组成的安全监测解决方案

振弦式轴力计和振弦采集仪组成的安全监测解决方案 振弦式轴力计和振弦采集仪是一种常用的结构安全监测工具,可以用于评估建筑物、桥梁、隧道或其他结构的结构健康状态和安全性能。这种监测方案较为先进、精确,并且能够监测长期的结构反应,因此…

Git指定分支或文件回退到指定版本

文章目录 一、分支回滚1.1、使用 git reset 命令1.2、使用 git revert 命令1.3、使用 git checkout 命令 二、文件回滚2.1、回滚未提交文件2.2、回滚已提交文件2.2.1、首先查看文件的历史版本2.2.2、找到你想要还原的版本2.2.3、将文件还原到你想要还原的版本2.2.4、提交代码 三…

便利高效双赢:无人机油气管道巡检全面升级

我国庞大的油气管道网络,包括原油、成品和天然气管道,因为地理区域广泛、建设年代久远、安全事故频发等现实因素,对管道的安全巡护与管理提出了更高的需求。在这一背景下,传统的人工巡护方式显然已经难以满足对高、精、准的要求。…

s_v_web_id或fp协议过签名,dy滑块

某音s_web_id或fp协议过签名 ‘h5_sdk_version’, ‘2.36.0’ "search_impr":{"entity_id":"1135137973613200"},"link_item_list":null,"user_permissions":null,"offline_info_list":null,"is_cf":…

计算机组成原理-页式存储器

文章目录 页式存储虚拟地址vs实地址页表:逻辑页->主存块号地址交换过程地址交换过程(增加TLB)总结 页式存储 把程序分散式地放到主存的不同块的地方 虚拟地址vs实地址 操作系统将逻辑地址映射到主存块中的物理地址,对应的物…

新疆大学与优艾智合机器人成立联合创新实验室

11月22日至24日,第五届中国工业互联网大赛新疆赛站决赛在新疆维吾尔自治区昌吉回族自治州昌吉市举行。在大赛中崭露头角的优秀解决方案,将为绿色工厂、绿色园区、绿色供应链等建设提供新的动能,促进工业绿色发展。 作为大赛的成果延伸&#…