前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >java字节码byte code简介

java字节码byte code简介

作者头像
程序那些事
发布于 2020-07-07 07:47:33
发布于 2020-07-07 07:47:33
1.4K00
代码可运行
举报
文章被收录于专栏:程序那些事程序那些事
运行总次数:0
代码可运行

简介

Byte Code也叫做字节码,是连接java源代码和JVM的桥梁,源代码编译成为字节码,而字节码又被加载进JVM中运行。字节码怎么生成,怎么查看字节码,隐藏在Byte Code背后的秘密是什么呢?快跟小师妹一起来看看吧。

Byte Code的作用

小师妹:F师兄,为什么Java需要字节码呢?直接编译成为机器码不是更快吗?

小师妹,Java的设计初衷是一次编写,到处运行。为了兼容各个平台的运行环境,java特别为各种平台设计了JVM。

我们可以把JVM看做是一种抽象,对外提供了统一的接口。这样我们只需要编写符合JVM规范的代码,即可在JVM中运行。

回想下之前我们提到过的java的执行过程:

  1. 编写java代码文件比如Example.java
  2. 使用java编译器javac将源文件编译成为Example.class文件
  3. JVM加载生成的字节码文件,将其转换成为机器可以识别的native machine code执行

小师妹:F师兄,我有一个大胆的想法,JVM的作用是将字节码解释或者编译成为机器码。然后在相应的运行环境中执行。那么有没有可能,不需要JVM,不需要机器码,而是直接在对应的平台上执行字节码呢?

爱因斯坦说过没有想像力的灵魂,就像没有望远镜的天文台。

小师妹你这个想法很好,这种实现有个专业的说法叫做:Java processor。

Java processor就是用硬件来实现的JVM。因此字节码可以直接在Java processor中运行。

其中比较出名的是Jazelle DBX,这是一个主要支持J2ME环境的硬件架构。为了提升java在手机端的执行速度。

但是这样做其实也是有缺点的,后面我们会讲到,java字节码中的指令非常非常多。所以如果用硬件来实现的话,就会非常非常复杂。

一般来说Java processor不会实现全部的字节码中的功能,只会提供部分的实现。

查看Byte Code字节码

小师妹:F师兄,那使用javac编译过后的class文件跟字节码有什么关系呢?

class文件中大部分都是byte code,其他的部分是一些meta data元数据信息。这些组合在一起就是class文件了。

小师妹:F师兄,你说class文件是byte code,为什么我在IDE中打开的时候,直接显示的是反编译出来的源文件呢?

小师妹,这是IDE的一个便利功能。因为大多数情况下,没有人想去看class文件的Byte code的,大家都是想去看看这个class文件的源文件是什么样的。

我们举个最简单的例子:

这个类中,我们定义了一个很简单的testByteCode方法,里面定义了两个变量,然后返回他们两个的和。

现在有两种方法来查看这个类的Byte Code:

第一种方法是用javap命令:

javap -c ByteCodeUsage.class

生成的结果如上所示。

第二种方法就是在IDEA中,选中class文件,然后在view中选中show Bytecode:

我们看下输出结果:

两个的结果在显示上面可能有细微的差异,但是并不影响我们后面对其的解析。

java Byte Code是怎么工作的

小师妹:F师兄,能讲解一下这些byte code到底是怎么工作的吗?

首先我们要介绍一下JVM的实现是基于栈的结构的。为什么要基于栈的结构呢?那是因为栈是最适合用来实现function互相调用的。

我们再回顾一下上面的testByteCode的字节码。里面有很多iconst,istore的东西,这些东西被称作Opcode,也就是一些基于栈的操作指令。

上面讲了java bytecode的操作指令其实有很多个。下面我们列出这些指令的部分介绍:

实在是太多了,这里就不把所有的列出来了。

我们看到的指令名字其实是一个助记词,真实的Opcode是一个占用两个字节的数字。

下面我们来详细解释一下testByteCode方法:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public int testByteCode();
    Code:
       0: iconst_1       
       1: istore_1       
       2: iconst_2       
       3: istore_2       
       4: iload_1       
       5: iload_2       
       6: iadd       
       7: ireturn

第一步,iconst_1将int 1加载到stack中。

第二步,istore_1将入栈的int 1出栈,并存储到变量1中。

第三步,iconst_2将int 2入栈。

第四步,istore_2将入栈的int 2出栈,并存储到变量2中。

第五步,iload_1将变量1中的值入栈。

第六步,iload_2将变量2中的值入栈。

第七步,iadd将栈中的两个变量出栈,并相加。然后将结果入栈。

第八步,ireturn将栈中的结果出栈。

这几步实际上完美的还原了我们在testByteCode方法中定义的功能。

当然我们只介绍了最简单的byte code命令,通过这些简单的命令可以组合成为更加复杂的java命令。

总结

本文介绍了java byte code的作用和具体的指令,并分析了一个简单的例子来做说明。希望大家能够掌握。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-06-25,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 程序那些事 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
5.java内存模型详细解析
Description of Java Conceptual Diagram(java结构)
用户7798898
2021/10/13
3260
一段处理异常的java代码的字节码解释
从JDK8开始,字节码处理finally时变为通过冗余finally代码块来解决。(jdk7以及之前可以通过jsr跳转指令处理。)
青山师
2023/05/05
2060
【Java 虚拟机原理】线程栈 | 栈帧 | 局部变量表 | 反汇编字节码文件 | Java 虚拟机指令手册 | 程序计数器
装载 HelloWorld.class 字节码文件到 Java 虚拟机内存中 , 会将该字节码文件中的数据进行分解 , 放到不同的内存区域中 ;
韩曙亮
2023/03/29
3310
【Java 虚拟机原理】线程栈 | 栈帧 | 局部变量表 | 反汇编字节码文件 | Java 虚拟机指令手册 | 程序计数器
【Java 虚拟机原理】栈帧 | 局部变量表 | 操作数栈 | 方法出口 | JVM 指令逐条解析
" 栈帧 " 中存储的是 局部变量表 , 操作数栈 , 动态链接 , 方法出口 ;
韩曙亮
2023/03/29
4010
【Java 虚拟机原理】栈帧 | 局部变量表 | 操作数栈 | 方法出口 | JVM 指令逐条解析
Java及JVM简介
懂得JVM内部的内存结构、工作机制,是设计高扩展性应用和诊断运行时问题的基础,也是Java工程师进阶的必备能力。 
一个风轻云淡
2023/10/15
1480
Java及JVM简介
Java命令之javap初探
javap是jdk自带的一个工具在jdk安装目录的/bin下面可以找到,可以对代码反编译,也可以查看java编译器生成的字节码,对代码的执行过程进行分析,了解jvm内部的工作。
haifeiWu
2018/09/11
6760
通过字节码理解try-catch-finally
结合这个异常表和Code中的注释,可以发现,如果try语句中发生了Exception及其子类异常,那么执行的字节码为第8-16行,最终返回值为2。其他异常的话,则跳到第17行处理,执行第17-23行,最终将异常抛出,方法值没有返回。
Java架构师必看
2021/11/29
3560
1、引言
栈帧对应一个线程的一个方法的内容,用于方法的执行,包括方法执行过程中的变量的临时状态。同时栈帧也执行动态链接,方法的返回值以及分发异常。栈帧被包含在JVM栈中。每一个栈帧包括:
文彬
2022/06/06
3820
1、引言
JVM笔记 -- JVM的发展以及基于栈的指令集架构
虚拟机,就是虚拟的计算机,可以执行一系列虚拟计算机指令,大体上可以分为系统虚拟机和程序虚拟机。它们运行时,都会受到虚拟机提供的资源的限制。
秦怀杂货店
2021/03/07
5690
JVM - 结合代码示例彻底搞懂Java内存区域_线程栈 | 本地方法栈 | 程序计数器
字节码文件被装载子系统装载到JVM中,字节码执行引擎负责执行这些字节码文件。 装载子系统和执行引擎都是C++的实现。
小小工匠
2021/08/17
3540
2.1 jvm内存模型
Description of Java Conceptual Diagram(java结构)
用户7798898
2020/09/27
4070
2.1 jvm内存模型
通过工具和字节码带你深入理解运行时数据区
上篇文章介绍了JVM运行时数据区的一些概念,这篇文章将通过工具和字节码加深对常用的堆和虚拟机栈部分的理解。
索码理
2022/12/28
2650
通过工具和字节码带你深入理解运行时数据区
[JVM] JVM自动内存管理机制(一)
文本主要就JVM结构和字节码文件,进行分析来展开JVM的学习,后续系列文章会从JVM的多个方面的进行知识总结。
架构探险之道
2019/09/09
5300
[JVM] JVM自动内存管理机制(一)
第一章、JVM和Java体系架构
最快的JVM,因为只使用了JIT,性能好。但是启动慢,需要编译所有字节码为本地机器指令。不过它专注于服务端,启动慢也就无所谓了。
Yuyy
2022/09/21
1910
第一章、JVM和Java体系架构
手写一个简单的JVM--02.模拟运行JVM
虚拟机栈是栈帧的集合的统称,栈帧是虚拟机执行时方法调用和方法执行时的数据结构,它是虚拟栈数据区的组成元素,每一个方法对应了一个栈帧。
付威
2020/06/11
1.4K0
Java字节码文件、组成,jclasslib插件、阿里arthas工具,Java注解
字节码文件中保存了源代码编译之后的内容,以二进制的方式存储,无法直接用记事本打开阅读。通过NotePad++使用十六进制插件查看class文件:
寻求出路的程序媛
2024/09/04
730
Java字节码文件、组成,jclasslib插件、阿里arthas工具,Java注解
字节码原理浅析 —— 基于栈的执行引擎
虚拟机常见的实现方式有两种:Stack based 的和 Register based。比如基于 Stack 的虚拟机有Hotspot JVM、.net CLR,这种基于 Stack 实现虚拟机是一种广泛的实现方法。而基于 Register 的虚拟机有 Lua 语言虚拟机 LuaVM 和 Google 开发的安卓虚拟机 DalvikVM。
架构狂人
2023/08/16
5690
字节码原理浅析 —— 基于栈的执行引擎
JVM合集之开篇点题
大家在平时的开发过程中是否遇到过StackOverflowError、OutOfMemoryError等类似的内存溢出错误呢?大家又是怎么解决这个问题的?再来,大家在面试过程中有没有被面试官提问过jvm的内部构造及如何优化的夺命连环call呢?今天就让我们来一探究竟,先从jvm的内部构造及原理说起,一步一步带大家解决jvm的优化问题。
阿Q说代码
2021/05/13
3710
JVM合集之开篇点题
如何从字节码角度分析Java问题
很简单的两行代码,如果是你遇到这样的问题,你会怎样去把问题解释清楚?是利用Java运算符顺序将式子拆解,然后一步步运算,还是其他什么办法?
叫我阿柒啊
2022/05/09
5850
如何从字节码角度分析Java问题
敖丙字节一面:能聊聊字节码么?
上一篇《你能和我聊聊Class文件么》中,我们对Class文件的各个部分做了简单的介绍,当时留了一个很重要的部分没讲,不是敖丙不想讲啊,而是这一部分实在太重要了,不独立成篇好好zhejinrong 讲讲都对不起詹姆斯·高斯林
敖丙
2022/04/19
3340
敖丙字节一面:能聊聊字节码么?
推荐阅读
相关推荐
5.java内存模型详细解析
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验