`
zhaohaolin
  • 浏览: 1011411 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Java字节码揭秘——第二部分

    博客分类:
  • JAVA
阅读更多
Java 字节码分类
JVM 字节码集合基本上是分为几个不同的大类的。我们不会逐一介绍字节码的操作符,我们讨论类别,然后着重拿出一些常用的操作符,其余的均可通过 JVM规范 来获取详情。
 
堆栈操作。
  • pop pop2 :将堆栈的值弹出。 pop2 用来弹出 64 位的值, pop 用来弹出 32 位的。
  • dup dup2 :复制堆栈顶端的值。用来形成高效的 pop/push/push 组合。 dup2 也是用在 64 位上的。
  • const_null null 的引用推送至堆栈。
  • bipush 将单字节的常量值 (-127~128) 推送至堆栈。
  • sipush 将一个短整型类型的常量值 (-32K~32K) 推送至堆栈。
  • ldc 将常量值从常量池中推送至堆栈。
  • Xload X 可为 a d f l 或者 i ,是将一个本地 ( 参数或变量 ) 的指定类型推送至堆栈。 a 指引用、 b 指布尔类型、 c 指字符、 d 指双精度类型、 f 指浮点类型、 i 指整型、 l 指长整型、 s 指短整型。该编码模式会在操作符的名字中重复出现。
  • Xstore X 可为 a d f l 或者 i ,将堆栈顶端的值弹出并放入本地分片中。
  • Xconst_Y 是操作符集合中一系列的优化操作,设计用来将 X 类型的常量 Y 值推送至堆栈。例如, iconst_0 就是将整数常量 0 推送至堆栈中,是 bipush 的高效硬编码变种。
 
分支与控制流。
  • nop ,啥也不做。
  • if( 条件 ) ,条件可以是 null notnull eq ne gt lt _icmpeq _icmpne ……。
  • goto Java 代码虽然不支持 goto ,但 JVM 是支持的。
  • return Xreturn X 可以为 a d f l 或者 i ,从当前调用方返回,将堆栈顶端作为 X 类型返回。
  • lookupswitch 提供了对 switch/case 表的实现。
 
算法指令。 JVM 操作符合其他 CPU 指令集一样有一些基本的算术运算符,例如加减乘除等,也包含一些基本的转换操作符进行放大与缩小的转换:
  • 数据转换操作符采用 XtoY 的形式, X Y 可以是 a d f l 或者 i ,堆栈的顶端取符合 X 格式的数,并将转换成 Y 格式后推送回堆栈。
  • 算术运算符采用 XOP 的格式, X 可为 d f i 或者 l OP 可为加减乘除和取余。
  • 字节操作符采用 iOP 的格式, OP 可为与、或、异或、左移位 (shift left) 、右移位 (shift right)
  • 比较操作符采用 XcmpY 的格式, X 可以是 d ,即基于双精度的比较; f ,即基于浮点的比较;或 l ,即基于长整型的比较。 Y 可以是 g 或者 l 。两个数比较,第一个 > 第二个,则将 1 推送至堆栈;如果 = ,则推送 0 ;如果 < ,则推送 -1
 
对象模型指令。 JVM 内置的专门为对象工作的操作符:创建对象、调用方法、访问属性等:
  • new newarray anewarray :创建一个新对象、创建一个数组和创建一个对象应用的数组。对象或数组被推送至堆栈的顶端。在 new 操作符时,并未调用构造函数,调用构造函数是后续代码的工作。
  • getfield setfield getstatic setstatic 。在设置值时,值在堆栈的顶端,而对象引用就正好在下方跟着。如果是静态属性的话,显然不需要任何对象引用。
  • invokevirtual invokestatic invokespecial invokeinterface 。它们都是调用方法的操作符,方法则由操作计数指定的常量池入口描述。使用推送至堆栈的值作为由左至右的调用参数,即调用的第一个参数位于堆栈的最下部; this 引用位于第一个,也就是在堆栈的最下部引用。 Invokevirtual 操作符表示调用是对对象方法的普通调用, invokeinterface 就是当通过接口的引用调用方法时, invokestatic 表示调用静态方法, invokespecial 表明无需考虑动态绑定的方法调用——为了调用特定版本的类的方法,而不管衍生覆盖类型。
  • castclass instanceof 。这两个操作符处理堆栈顶部的引用转换为操作计数隐含的类型。如果成功,新引用或 true 将被推送至堆栈顶端,如果失败,则 CastClassException 异常或 false 被推送。
 
块同步 ( 同步块或方法 ) 块同步由两个操作符处理, monitorenter monitorexit 。当调用对象试图获取监控器的代码时,它们都在堆栈上分别持有该对象的引用。事实上是编译器负责保证均衡的出入口调用,所以同步方法或同步块通常需要在 try/finally 块中来保证 monitorexit 操作符一定会被调用。如果不这样做的话,就会让监控器一直被线程占有,最终导致死锁。
 
异常处理。 异常处理并非通过特殊的操作符集合来处理,而是通过创建一个表格,里面标记了块指令——监视并创建一系列的包括需要做什么的入口,也即当特定类型的异常抛出后的操作符偏移量。
分享到:
评论

相关推荐

    轻松看懂Java字节码.pdf

    文档中提到的内容部分通过一个简单的Java类和其对应的字节码来演示了如何解读和理解字节码。 总而言之,Java字节码是Java平台的核心技术之一,它使Java程序具有跨平台的特性,并且为基于JVM的多种编程语言提供了一...

    JAVA字节码JAVA字节码.doc

    Java 字节码编程 Java 字节码是 Java 程序的中间表示形式,它可以被 Java 虚拟机(JVM)解释执行。了解 Java 字节码可以帮助开发者更好地理解 Java 程序的执行机制,提高程序的执行效率和排除错误。 一、Java 类...

    java字节码加密

    Java字节码加密是保护Java应用程序源代码安全的重要技术手段,主要是为了防止恶意用户逆向工程分析、篡改或盗取程序的核心逻辑。在Java中,字节码(Bytecode)是程序经过编译后的中间表示,可以直接由Java虚拟机...

    Java字节码转换工具—Retrotranslator

    Java字节码转换工具Retrotranslator是一个用于解决软件兼容性问题的实用工具,尤其是在Java版本升级带来的不兼容性上。随着Java技术的不断迭代,新版本的特性常常不能在旧版本的JDK环境下运行,而Retrotranslator的...

    Java 字节码概述

    Java 字节码概述 Java 字节码是 Java 虚拟机(JVM)执行 Java 语言编译后的结果。Java 字节码是一种平台无关的中间形式,能够在不同的操作系统和硬件平台上运行。Java 字节码的执行是由 JVM 负责的,它将字节码翻译...

    class运行器v6(可以运行java字节码文件的工具 含代码)

    标题中的“class运行器v6”是一个用于执行Java字节码文件的应用程序,它允许用户在没有完整Java环境的情况下运行单个.class文件。这个工具可能是由开发者为了方便测试或教学目的而创建的,特别是对于那些不熟悉或者...

    java字节码编辑器

    在使用这类编辑器时,用户需要对Java虚拟机(JVM)的指令集有一定的了解,因为字节码本质上就是JVM可执行的二进制指令。 Java字节码是由一系列16进制数字组成的,每个字节对应一个或多个JVM指令。这些指令控制着JVM...

    Java字节码优化框架

    2. 中间表示转换:将输入转换为内部的Jimple或其他IR形式,这一步通常涉及到源代码到字节码的预处理,例如使用Polyglot编译Java源代码。 3. 分析和优化:基于IR进行代码分析和优化,例如消除冗余计算、常量折叠、...

    java字节码文件查看工具,查看class文件

    Java字节码文件查看工具,如JD-GUI,是开发者们深入理解Java应用程序内部机制的重要辅助工具。这类工具能够帮助我们查看并分析.class文件,这些文件是Java源代码经过编译后的二进制形式,包含了运行时所需的所有指令...

    java字节码分析工具

    Java字节码分析工具,系统分析了java字节码文件,即java class类文件,对该文件中的各种成分以树的形式描述出来,只能针对未加密的class文件,一般由标准java编译器编译生成的class文件都未加密,该系统在vs2003下面...

    java字节码.docx

    Java 字节码解读 Java 字节码是一种中间形式的代码,它是 Java 源代码编译后的结果。Java 字节码是平台独立的,可以在任何支持 Java 的设备上运行。Java 字节码的结构主要包括魔数、主版本号、次版本号、常量池、...

    Java字节码简单说明.docx

    Class 文件结构是 Java 字节码的载体,它是一种特殊的二进制文件格式,包含了 Java 虚拟机指令集和符号表以及若干其他辅助信息。Class 文件中存储了 Java 程序的定义信息,但它并不一定以磁盘文件的形式存在。 ...

    一个牛逼的 Java 字节码类库!(csdn)————程序.pdf

    Java 字节码是Java平台的一种低级表示形式,它是由JVM(Java虚拟机)理解和执行的二进制代码。字节码使得Java程序具有跨平台性,因为不同的操作系统上的JVM可以解析并运行相同的字节码。在Java中,我们可以通过API来...

    Java 字节码简单说明.zip

    总的来说,Java字节码是Java平台的核心组成部分,它使得Java程序具有跨平台性和高效执行的特性。通过学习和理解字节码,开发者能更深入地掌握Java的运行机制,从而编写出更高效、更安全的代码。

    Java字节码(.class文件)格式详解((转载)

    Java字节码是Java程序在运行时被JVM(Java虚拟机)解释执行的一种中间语言。每个Java类都由一个`.class`文件表示,其中包含了编译后的字节码指令。`.class`文件的结构非常严谨,它不仅包含了类的信息,如类名、方法...

    从一个class文件深入理解Java字节码结构

    Java程序在执行时,首先需要通过Java编译器将源代码(.java文件)编译成二进制的字节码文件(.class文件),这些字节码由Java虚拟机(JVM)解析并执行。深入理解字节码结构有助于我们了解Java程序的运行机制,优化...

    javassist, Java字节码工程工具包.zip

    javassist, Java字节码工程工具包 Java字节码工程工具包 版本 3版权所有( C ) 1999 -2017按 Shigeru Chiba,保留所有权利。Javassist ( Java编程助手) 使Java字节码操作简单。 它是一个类库,用于在Java中编辑字节码

    JAVA字节码操作库 BCEL

    1. **字节码**:Java字节码是Java虚拟机(JVM)运行的二进制代码,它由javac编译器将源代码编译成。每个类都有一个`.class`文件,其中包含了该类的字节码。 2. **API组件**:BCEL包含一系列接口和类,如`ClassGen`,...

Global site tag (gtag.js) - Google Analytics