JVM-02

embedded/2024/9/23 13:53:30/

字节码文件是一种特殊的文件格式,它包含了将源代码转换为机器可执行代码所需的指令集。字节码文件通常是由编译器将源代码编译为字节码的中间表示形式。
在Java中,字节码文件的扩展名为.class,它存储了编译后的Java代码。这些字节码文件可以在Java虚拟机上运行,并将字节码转换为机器代码来执行。
字节码文件中的指令通常是基于栈的操作,它们被设计成与Java虚拟机的指令集兼容。这使得字节码文件可以在不同的计算机上运行,只要这些计算机有一个能够解释和执行字节码的Java虚拟机。
除了Java,其他编程语言如Python、Ruby和C#等也有类似的字节码文件。这些字节码文件在执行时会被相应的虚拟机解释和执行。

字节码文件主要信息:
1.基础信息:魔数、字节码文件对应的Java版本号,访问标识(public final等等),父类和接口。
2.常量池:保存了字符串常量、类或接口名、字段名,主要在字节码指令中使用。
3.字段:当前类或接口声明的字段信息。
4.方法:当前类或接口声明的方法信息,字节码指令。
5.属性:类的属性,比如源码的文件名,内部类的列表等。

Java字节码文件中,将文件头称为magic魔数。 CAFEBABE

常量池中的数据都有一个编号,编号从1开始。在字段或者字节码指令中通过编号可以快速的找到对应的数据。
字节码指令中通过编号引用到常量池的过程称之为符号引用。

Arthas 是一款线上监控诊断产品,通过全局视角实时查看应用 load、内存、gc、线程的状态信息,并能在不修改应用代码的情况下,对业务问题进行诊断,大大提升线上问题排查效率。
官网:https://arthas.aliyun.com/doc/
dump 类的全限定名:dump已加载类的字节码文件到特定目录。
jad类的全限定名:反编译已加载类的源码。


http://www.ppmy.cn/embedded/33066.html

相关文章

vue设置必填项

表单&#xff1a; <el-form-item label"标题" prop"title" ><el-input placeholder"标题" v-model"form.title"></el-input></el-form-item> 在data中添加一个rules来规定 rules: {title: [{ required: t…

Golang日志管理精讲:`log`库的高级用法与性能优化

Golang日志管理精讲&#xff1a;log库的高级用法与性能优化 引言log库概览核心组件介绍日志级别的设置标准Logger与自定义Logger 基础用法创建基础日志实例日志级别的设置标准Logger与自定义Logger 高级技巧日志格式自定义多日志文件分流集成系统服务中的日志管理 并发与性能优…

【Nginx 开发】反向代理配置,负载均衡配置,动静分离配置

nginx 配置 反向代理配置负载均衡配置动静分离 反向代理 我们根据实例进行讲解&#xff0c;效果是通过在浏览器访问www.hlh.com,跳转到Linux系统的tomcat主页面中 第一步&#xff1a;在windows系统的host文件进行域名和ip对应关系的配置 在host文件中添加自己的地址映射 192.…

大语言模型从Scaling Laws到MoE

1、摩尔定律和伸缩法则 摩尔定律&#xff08;Moores law&#xff09;是由英特尔&#xff08;Intel&#xff09;创始人之一戈登摩尔提出的。其内容为&#xff1a;集成电路上可容纳的晶体管数目&#xff0c;约每隔两年便会增加一倍&#xff1b;而经常被引用的“18个月”&#xf…

C++关联容器1——map,multimap,set,multiset介绍,pair类型

目录 关联容器 使用关联容器 使用map 使用set 关联容器概述 定义关联容器 初始化multimap或multiset 关键字类型的要求 有序容器的关键字类型 使用关键字类型的比较函数 pair 类型 创建pair 对象的函数 关联容器 关联容器支持高效的关键字查找和访问。 两个主要的关…

Redis实际应用中的解决方案

Redis缓存使用问题 1数据一致性 分析一下几种方案&#xff1a; 1&#xff1a;先更新缓存&#xff0c;再更新数据库 2&#xff1a;先更新数据库&#xff0c;在更新缓存 3&#xff1a;先删除缓存&#xff0c;后更新数据库 4&#xff1a;想更新数据库&#xff0c;后删除缓存 …

【数据结构】集合与散列表

文章目录 集合基本概念静态查找表顺序查找顺序表查找有序表的顺序查找 折半查找非递归折半查找递归折半查找 分块查找 动态查找表二叉查找树查找递归查找非递归查找 插入递归插入非递归插入 删除递归删除非递归删除算法 散列表概念构造的方法平方取中法除留余数法 解决冲突的方…

刷代码随想录有感(56):二叉搜索树的最小绝对差

题干&#xff1a; 代码:中序遍历成有序数组逐一比较相邻两个数之间的差值&#xff0c;注意这里是取最小值所以定义的初始值应该是非常大的INT_MAX&#xff01;&#xff01;&#xff01; class Solution { public:void traversal(TreeNode* root, vector<int>&a){if(…