当前位置: 首页 > news >正文

一文流:JVM精讲(多图提醒⚠️)

一文流系列是作者苦于技术知识学了-忘了背了-忘了的苦恼,决心把技术知识的要点一笔笔✍️出来,一图图画出来,一句句讲出来,以求刻在🧠里。

该系列文章会把核心要点提炼出来,以求掌握精髓,至于其他细节,写在文章里,留待后续回忆。

目前进度请查看:

:::info
https://www.yuque.com/u1949579/vtk1e4/fuq6986htl8yy9bg?singleDoc# 《我的技术栈-思维导图》

:::

猛图开局,自己看去吧。

引用自:Java虚拟机-JVM初识(体系结构, 栈stack, 堆heap, GC, Jprofiler,JVM参数 )_jvm total-CSDN博客

JVM是个啥?

JVM(Java Virtual Machine)是 Java 程序运行的核心组件,它提供了一个独立于硬件和操作系统的执行环境,使得 Java 程序能够在不同平台上具有跨平台的特性。

JVM 主要实现商:

JVM 实现开发商特点支持的操作系统应用场景
HotSpot VMOracle性能优化出色,广泛应用,具有自适应优化技术,不断迭代更新。Windows、Linux、Mac OS 等多种主流操作系统适用于各类企业级应用、桌面应用以及服务器端应用开发,是 Java 应用的主流选择。
OpenJDK开源社区(Oracle 主导)开源免费,与 HotSpot VM 有紧密联系,代码开源利于社区贡献和定制化开发。多种操作系统,与 HotSpot VM 兼容的系统基本都支持在开源项目、学术研究以及对成本敏感且需要自主定制的场景中广泛应用,也是许多 Linux 发行版默认的 JVM 选择。
JRockitBEA Systems(后被 Oracle 收购)专注于服务器端应用性能,在大规模并发和高性能计算场景下表现优异,有专门的优化策略。主要支持 Linux、Solaris、Windows 等服务器常用操作系统在企业级服务器应用中,特别是对性能和稳定性要求极高的关键业务系统中发挥优势,不过目前已逐渐被 HotSpot 融合和取代。
IBM J9 VMIBM针对 IBM 硬件和软件生态系统有较好的适配性和优化,具有良好的稳定性和性能,支持多种编程语言。AIX、Linux、Windows、z/OS 等 IBM 相关操作系统以及其他一些主流系统常用于 IBM 的服务器产品、企业级解决方案以及金融等行业的关键业务系统,与 IBM 硬件和软件紧密集成,提供整体解决方案。

JVM 主要构成及其作用(了解即可)

JVM主要由类加载器系统,运行时数据区,执行引擎和本地方法接口/库 四部分组成。下面的脑图详细介绍了其详细结构和主要作用说明。

画板

JVM工作流程(掌握)

上图展示了主要工作流程的交互关系。下面介绍下简要的工作流程,特别容易考察的点会单独列出来说明。

  1. 编译:.java 文件经过编译形成.class 文件

基本流程:词法分析 -> 语法分析 -> 语义分析 -> 字节码生成 【不必理会】

  1. 加载:类加载器查找并加载.class文件并将类相关信息存储到元空间(JDK7:方法区)

流程参考:JVM类加载运行全过程

画板

  1. 执行:字节码执行,将.class中的java字节码解释/JIT成操作系统可识别的机器码
  2. 运行时:运行时数据区管理、内存分配与垃圾回收阶段(与字节码执行阶段交叉进行)
  3. 结束:程序结束

类加载的双亲委派机制(重要)

在加载一个类时,类加载器会先将加载请求委托给它的父加载器,只有当父加载器无法完成加载时,才会由自己去加载。这种机制可以保证 Java 核心类库的一致性和安全性,避免类加载冲突(完全限定名必须唯一)。

eg1. 加载 java.util.List.class

提交 -> UserClassLoader.loadClass(java.util.List.class);

委托 --> ApplicationClassLoader.loadClass(java.util.List.class);

委托 —> ExtensionClassLoader.loadClass(java.util.List.class);

委托 ----> BootsratpClassLoader.loadClass(java.util.List.class); 加载成功!

对应代码:

// ClassLoader 类代码,示例用途已删除部分代码
public abstract class ClassLoader {protected Class<?> loadClass(String name, boolean resolve)throws ClassNotFoundException{synchronized (getClassLoadingLock(name)) {// 从内存中查找已经加载过的类Class<?> c = findLoadedClass(name);if (c == null) {long t0 = System.nanoTime();try {// 查找父类, 优先由父类加载if (parent != null) {c = parent.loadClass(name, false);} else {// 这里注意BootstrapClassLoader不是java实现的// 所以层级结构没办法在java维护,需要调用native方法。c = findBootstrapClassOrNull(name);}} catch (ClassNotFoundException e) {}if (c == null) {// 如果仍然查找不到类,则由当前加载器查找类long t1 = System.nanoTime();c = findClass(name);}}if (resolve) {resolveClass(c);}return c;}}
}

类加载时静态成员/代码块的执行(重要)

类的静态变量和静态代码块会在类加载的准备阶段和初始化阶段进行处理。

  • 在准备阶段,静态变量会被赋初始值(零值)
  • 初始化阶段,会按照代码编写的顺序执行静态变量的赋值语句和静态代码块。
// 假如类中声明
public static int num = 10;
// 类加载。准备阶段 -> 元空间
num = 0;//0是int类型的初始值
// 类加载。初始化阶段 -> new 或访问类,比如访问类的静态方法

注意:静态变量赋值先于静态代码块执行。

类加载器的自定义和隔离性(了解即可)

自定义的类加载器,可以自行实现 ClassLoader 以实现加载同名的Java,这常用于加载自定义插件。

如下案例:

  1. 先编译类
kern@MBP plugins %  javac p1/cn/kern/demo/local/classloader/PluginObject.java 
kern@MBP plugins %  javac p2/cn/kern/demo/local/classloader/PluginObject.java
kern@MBP plugins % ll p1/cn/kern/demo/local/classloader/PluginObject.class 
-rw-r--r--  1 kern  staff  229 Dec 12 14:55 p1/cn/kern/demo/local/classloader/PluginObject.class
kern@MBP plugins % ll p2/cn/kern/demo/local/classloader/PluginObject.class
-rw-r--r--  1 kern  staff  229 Dec 12 14:55 p2/cn/kern/demo/local/classloader/PluginObject.class

对应的类,相同的名字,不同的存放地方和实现。

// 去掉部分代码
public class PluginObject {static long time;static {time = new Date().getTime();}public void hello() {System.out.println("I'm P1 Plugin Object, loaded at " + time);}
}
// 去掉部分代码
public class PluginObject {static long time;static {time = new Date().getTime();}public void hello() {System.out.println("I'm P2 Plugin Object, loaded at " + time);}
}

  1. 实现自定义ClassLoader
public class MyClassLoader extends ClassLoader {private final String classPath;public MyClassLoader(String classPath) {this.classPath = classPath;}// 重写 findClass 方法@Overrideprotected Class<?> findClass(String name) throws ClassNotFoundException {byte[] classData = loadClassData(name);if (classData == null) {throw new ClassNotFoundException();}return defineClass(name, classData, 0, classData.length);}// 自定义读取类数据的方法protected byte[] loadClassData(String name) throws ClassNotFoundException {try {// 将包名中的 . 替换为路径分隔符 /String fileName = classPath + name.replace</

相关文章:

一文流:JVM精讲(多图提醒⚠️)

一文流系列是作者苦于技术知识学了-忘了,背了-忘了的苦恼,决心把技术知识的要点一笔笔✍️出来,一图图画出来,一句句讲出来,以求刻在🧠里。 该系列文章会把核心要点提炼出来,以求掌握精髓,至于其他细节,写在文章里,留待后续回忆。 目前进度请查看: :::info https:/…...

python 分段拟合笔记

效果图: 源代码: import numpy as np import cv2 import matplotlib.pyplot as plt from numpy.polynomial.polynomial import Polynomialdef nihe(x_points,y_points,p_id):# 按照 p_id 将 points 分成两组group_0_x = []group_0_y = []group_1_x = []group_1_y = []for i, …...

Mysql索引类型总结

按照数据结构维度划分&#xff1a; BTree 索引&#xff1a;MySQL 里默认和最常用的索引类型。只有叶子节点存储 value&#xff0c;非叶子节点只有指针和 key。存储引擎 MyISAM 和 InnoDB 实现 BTree 索引都是使用 BTree&#xff0c;但二者实现方式不一样&#xff08;前面已经介…...

数据结构——队列的模拟实现

大家好&#xff0c;上一篇博客我带领大家进行了数据结构当中的栈的模拟实现 今天我将带领大家实现一个新的数据结构————队列 一&#xff1a;队列简介 首先来认识一下队列&#xff1a; 队列就像我们上学时的排队一样&#xff0c;有一个队头也有一个队尾。 有人入队的话就…...

在window环境下安装openssl生成钥私、证书和签名,nodejs利用express实现ssl的https访问和测试

在生成我们自己的 SSL 证书之前&#xff0c;让我们创建一个简单的 Express应用程序。 要创建一个新的 Express 项目&#xff0c;让我们创建一个名为node-ssl -server 的目录&#xff0c;用终端cmd中进入node-ssl-server目录。 cd node-ssl-server 然后初始化一个新的 npm 项目…...

Redis 最佳实践

这是以前写下来的文章&#xff0c;发出来备份一下 Redis 在企业中的最佳实践可以帮助提高性能、可用性和数据管理效率。以下是一些推荐的做法&#xff1a; 选择合适的数据结构&#xff1a; 根据需求选择适当的 Redis 数据结构&#xff08;如 Strings、Lists、Sets、Hashes、So…...

网站灰度发布?Tomcat的8005、8009、8080三个端口的作用什么是CDNLVS、Nginx和Haproxy的优缺点服务器无法开机时

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c; 忍不住分享一下给大家。点击跳转到网站 学习总结 1、掌握 JAVA入门到进阶知识(持续写作中……&#xff09; 2、学会Oracle数据库入门到入土用法(创作中……&#xff09; 3、手把…...

从客户跟进到库存管理:看板工具赋能新能源汽车销售

在新能源汽车市场日益扩张的今天&#xff0c;门店销售管理变得更加复杂和重要。从跟踪客户线索到优化订单流程&#xff0c;再到团队协作&#xff0c;效率低下常常成为许多门店的“隐形成本”。如果你曾为销售流程不畅、客户管理混乱而苦恼&#xff0c;那么一种简单直观的工具—…...

算法时间空间复杂度的计算

一、时间复杂度 &#xff1a;找循环最内层 二、空间复杂度&#xff1a; 1.找int float等变量 2.递归调用&#xff1a;空间复杂度递归调用的深度 int 型变量: 四个字节...

人才画像系统如何支撑企业的人才战略落地

在当今竞争激烈的商业环境中&#xff0c;企业的人才战略对于其长期发展至关重要。为了有效实施人才战略&#xff0c;企业需要一套精准、高效的人才管理工具&#xff0c;而人才画像系统正是满足这一需求的关键解决方案。本文将探讨人才画像系统如何支撑企业的人才战略落地&#…...

[数据结构] 链表

目录 1.链表的基本概念 2.链表的实现 -- 节点的构造和链接 节点如何构造? 如何将链表关联起来? 3.链表的方法(功能) 1).display() -- 链表的遍历 2).size() -- 求链表的长度 3).addFirst(int val) -- 头插法 4).addLast(int val) -- 尾插法 5).addIndex -- 在任意位置…...

三格电子——新品IE103转ModbusTCP网关

型号&#xff1a;SG-TCP-IEC103 产品概述 IE103转ModbusTCP网关型号SG-TCP-IEC103&#xff0c;是三格电子推出的工业级网关&#xff08;以下简称网关&#xff09;&#xff0c;主要用于IEC103数据采集、DLT645-1997/2007数据采集&#xff0c;IEC103支持遥测和遥信&#xff0c;可…...

遥感影像目标检测:从CNN(Faster-RCNN)到Transformer(DETR

我国高分辨率对地观测系统重大专项已全面启动&#xff0c;高空间、高光谱、高时间分辨率和宽地面覆盖于一体的全球天空地一体化立体对地观测网逐步形成&#xff0c;将成为保障国家安全的基础性和战略性资源。未来10年全球每天获取的观测数据将超过10PB&#xff0c;遥感大数据时…...

深入详解神经网络基础知识——理解前馈神经网络( FNN)、卷积神经网络(CNN)和循环神经网络(RNN)等概念及应用

深入详解神经网络基础知识 深度学习作为人工智能&#xff08;AI&#xff09;的核心分支之一&#xff0c;近年来在各个领域取得了显著的成果。从图像识别、自然语言处理到自动驾驶&#xff0c;深度学习技术的应用无处不在。而深度学习的基础&#xff0c;神经网络&#xff0c;是理…...

react 项目打包二级目 使用BrowserRouter 解决页面刷新404 找不到路由

使用BrowserRouter package 配置 &#xff08;这部分代码可以不做配置也能实现&#xff09; {"homepage": "/admin",}vite.config 配置 export default defineConfig({base: /admin])BrowserRouter 添加配置项 <BrowserRouter basename/admin>&l…...

EasyPlayer.js播放器Web播放H.265要兼顾哪些方面?

在数字化时代&#xff0c;流媒体技术已经成为信息传播和娱乐消费的重要方式。随着互联网技术的飞速发展和移动设备的普及&#xff0c;流媒体服务正在重塑我们的生活和工作方式。从视频点播、在线直播到音乐流媒体&#xff0c;流媒体技术的广泛应用不仅改变了内容的分发和消费模…...

使用 acme.sh 申请域名 SSL/TLS 证书完整指南

使用 acme.sh 申请域名 SSL/TLS 证书完整指南 简介为什么选择 acme.sh 和 ZeroSSL&#xff1f;前置要求安装过程 步骤一&#xff1a;安装 acme.sh步骤二&#xff1a;配置 ZeroSSL 证书申请 方法一&#xff1a;手动 DNS 验证&#xff08;推荐新手使用&#xff09;方法二&#xf…...

睡岗和玩手机数据集,4653张原始图,支持YOLO,VOC XML,COCO JSON格式的标注

睡岗和玩手机数据集&#xff0c;4653张原始图&#xff0c;支持YOLO&#xff0c;VOC XML&#xff0c;COCO JSON格式的标注 数据集分割 训练组70&#xff05; 3257图片 有效集20&#xff05; 931图片 测试集10&#xff05; 465图片 预处理 没有采用任何预处…...

[Unity] 【VR】【游戏开发】在VR中使用New Input System获取按键值的完整教程

在使用Unity开发VR项目时,推荐使用 New Input System 来处理输入操作。相比于旧的Input系统,New Input System更加灵活、功能强大,尤其在处理VR控制器的按键输入时具有明显优势。本文将详细介绍如何在VR项目中使用New Input System获取按键值,并通过代码示例和图文讲解,帮…...

网络安全渗透有什么常见的漏洞吗?

弱口令与密码安全问题 THINKMO 01 暴力破解登录&#xff08;Weak Password Attack&#xff09; 在某次渗透测试中&#xff0c;测试人员发现一个网站的后台管理系统使用了非常简单的密码 admin123&#xff0c;而且用户名也是常见的 admin。那么攻击者就可以通过暴力破解工具&…...

快马AI一键生成链表可视化原型,交互演示助力算法设计

最近在复习数据结构时&#xff0c;发现链表这种基础但重要的结构&#xff0c;光看静态图示很难理解指针变化。正好尝试用InsCode(快马)平台快速搭建了一个可视化演示工具&#xff0c;整个过程比想象中简单很多&#xff0c;分享下实现思路&#xff1a; 需求拆解 首先明确需要实现…...

3000+开源蓝图:革新性一站式戴森球计划工厂解决方案

3000开源蓝图&#xff1a;革新性一站式戴森球计划工厂解决方案 【免费下载链接】FactoryBluePrints 游戏戴森球计划的**工厂**蓝图仓库 项目地址: https://gitcode.com/GitHub_Trending/fa/FactoryBluePrints 面对戴森球计划中错综复杂的生产线布局&#xff0c;你是否曾…...

QIP 2023:亚马逊量子计算三篇论文突破

量子技术 某机构在QIP 2023发表的量子计算论文 针对“超级Grover”优化、拓扑数据分析的量子算法以及物理系统模拟的研究&#xff0c;展示了某机构在量子计算领域的广泛兴趣。 作者&#xff1a; Fernando Brando 日期&#xff1a; 2023年2月2日 阅读时间&#xff1a; 7分钟 在今…...

为什么你的视觉检测准确率卡在92.7%?(揭秘工业现场3类未标注异常数据导致的模型过拟合代码根源)

第一章&#xff1a;视觉检测准确率瓶颈的工业现场真相在实际产线部署中&#xff0c;视觉检测模型在实验室达到99.2%的mAP&#xff0c;落地后却频繁出现漏检与误报——这不是算法缺陷&#xff0c;而是工业现场多维干扰叠加的真实映射。光照波动、工件表面反光、传送带抖动、镜头…...

MongoDB从零基础搭建到实战

MongoDB从零基础搭建到实战 MongoDB作为当下最流行的开源文档型NoSQL数据库&#xff0c;凭借灵活的文档结构、高扩展性和易用性&#xff0c;成为前后端开发、大数据存储、云原生项目的首选数据库之一。相比传统关系型数据库&#xff0c;它无需严格预定义表结构&#xff0c;适配…...

别再让死区拖后腿!用MATLAB Simulink给SVPWM逆变器做个精准‘补偿手术’

电力电子工程师实战&#xff1a;用MATLAB Simulink实现SVPWM逆变器的死区补偿 在电力电子系统设计中&#xff0c;死区效应就像电路板上的隐形杀手——它不会立即摧毁你的系统&#xff0c;却会悄无声息地降低整体性能。作为一名长期奋战在电机控制一线的工程师&#xff0c;我见过…...

用ESP32和2.13寸墨水屏,我把汉朔电子价签改造成了桌面网络时钟(附完整代码)

用ESP32和2.13寸墨水屏打造极简网络时钟&#xff1a;从电子价签到桌面艺术 在智能硬件爱好者的世界里&#xff0c;总有一些被遗忘的电子元件等待重生。汉朔电子价签的2.13寸墨水屏就是这样一个被低估的宝藏——它低功耗、高对比度的特性&#xff0c;配合ESP32的强大无线功能&am…...

解决Qt程序异常结束的终极指南:从pro文件配置到动态库加载

Qt程序异常崩溃全链路排查手册&#xff1a;从配置陷阱到动态库依赖治理 当你盯着QtCreator控制台里那个刺眼的"程序异常结束"提示时&#xff0c;内心是否在咆哮&#xff1a;"明明代码逻辑没问题&#xff0c;为什么还会崩溃&#xff1f;"这不是你一个人的困…...

图片木马检测与防御:如何用PHP代码识别恶意图片上传(2024最新版)

图片木马检测与防御&#xff1a;2024年PHP实战指南 在数字化浪潮中&#xff0c;图片上传功能已成为网站标配&#xff0c;但这也为攻击者提供了可乘之机。去年某电商平台因图片木马导致百万用户数据泄露的事件&#xff0c;再次敲响了安全警钟。本文将深入剖析如何用PHP构建坚不可…...

Screencast Keys深度解析:从实时事件捕获到Blender操作可视化进阶指南

Screencast Keys深度解析&#xff1a;从实时事件捕获到Blender操作可视化进阶指南 【免费下载链接】Screencast-Keys Blender Add-on: Screencast Keys 项目地址: https://gitcode.com/gh_mirrors/sc/Screencast-Keys Screencast Keys作为Blender生态系统中一款专注于操…...