`

java字节码规则

    博客分类:
  • Java
 
阅读更多

栈和局部变量操作
将常量压入栈的指令
aconst_null         将null对象引用压入栈
iconst_m1         将int类型常量-1压入栈
iconst_0         将int类型常量0压入栈
iconst_1         将int类型常量1压入栈
iconst_2         将int类型常量2压入栈
iconst_3         将int类型常量3压入栈
iconst_4         将int类型常量4压入栈
iconst_5         将int类型常量5压入栈
lconst_0         将long类型常量0压入栈
lconst_1         将long类型常量1压入栈
fconst_0         将float类型常量0压入栈
fconst_1         将float类型常量1压入栈
dconst_0         将double类型常量0压入栈
dconst_1         将double类型常量1压入栈
bipush             将一个8位带符号整数压入栈
sipush             将16位带符号整数压入栈
ldc             把常量池中的项压入栈
ldc_w             把常量池中的项压入栈(使用宽索引)
ldc2_w             把常量池中long类型或者double类型的项压入栈(使用宽索引)
从栈中的局部变量中装载值的指令
iload             从局部变量中装载int类型值
lload             从局部变量中装载long类型值
fload             从局部变量中装载float类型值
dload             从局部变量中装载double类型值
aload             从局部变量中装载引用类型值(refernce)
iload_0             从局部变量0中装载int类型值
iload_1             从局部变量1中装载int类型值
iload_2             从局部变量2中装载int类型值
iload_3             从局部变量3中装载int类型值
lload_0             从局部变量0中装载long类型值
lload_1             从局部变量1中装载long类型值
lload_2             从局部变量2中装载long类型值

 

lload_3             从局部变量3中装载long类型值
fload_0             从局部变量0中装载float类型值
fload_1             从局部变量1中装载float类型值
fload_2             从局部变量2中装载float类型值
fload_3             从局部变量3中装载float类型值
dload_0             从局部变量0中装载double类型值
dload_1             从局部变量1中装载double类型值
dload_2             从局部变量2中装载double类型值
dload_3             从局部变量3中装载double类型值
aload_0             从局部变量0中装载引用类型值
aload_1             从局部变量1中装载引用类型值
aload_2             从局部变量2中装载引用类型值
aload_3             从局部变量3中装载引用类型值
iaload             从数组中装载int类型值
laload             从数组中装载long类型值
faload             从数组中装载float类型值
daload             从数组中装载double类型值
aaload             从数组中装载引用类型值
baload             从数组中装载byte类型或boolean类型值
caload             从数组中装载char类型值
saload             从数组中装载short类型值
将栈中的值存入局部变量的指令
istore             将int类型值存入局部变量
lstore             将long类型值存入局部变量
fstore             将float类型值存入局部变量
dstore             将double类型值存入局部变量
astore             将将引用类型或returnAddress类型值存入局部变量
istore_0         将int类型值存入局部变量0
istore_1         将int类型值存入局部变量1
istore_2         将int类型值存入局部变量2

 

istore_3         将int类型值存入局部变量3
lstore_0         将long类型值存入局部变量0
lstore_1         将long类型值存入局部变量1
lstore_2         将long类型值存入局部变量2
lstore_3         将long类型值存入局部变量3
fstore_0         将float类型值存入局部变量0
fstore_1         将float类型值存入局部变量1
fstore_2         将float类型值存入局部变量2
fstore_3         将float类型值存入局部变量3
dstore_0         将double类型值存入局部变量0
dstore_1         将double类型值存入局部变量1
dstore_2         将double类型值存入局部变量2
dstore_3         将double类型值存入局部变量3
astore_0         将引用类型或returnAddress类型值存入局部变量0
astore_1         将引用类型或returnAddress类型值存入局部变量1
astore_2         将引用类型或returnAddress类型值存入局部变量2
astore_3         将引用类型或returnAddress类型值存入局部变量3
iastore             将int类型值存入数组中
lastore             将long类型值存入数组中
fastore             将float类型值存入数组中
dastore             将double类型值存入数组中
aastore             将引用类型值存入数组中
bastore             将byte类型或者boolean类型值存入数组中
castore             将char类型值存入数组中
sastore             将short类型值存入数组中
wide指令
wide             使用附加字节扩展局部变量索引
通用(无类型)栈操作
nop             不做任何操作
pop             弹出栈顶端一个字长的内容
pop2             弹出栈顶端两个字长的内容
dup             复制栈顶部一个字长内容
dup_x1             复制栈顶部一个字长的内容,然后将复制内容及原来弹出的两个字长的内容压入栈

 

 

dup_x2             复制栈顶部一个字长的内容,然后将复制内容及原来弹出的三个字长的内容压入栈
dup2             复制栈顶部两个字长内容
dup2_x1             复制栈顶部两个字长的内容,然后将复制内容及原来弹出的三个字长的内容压入栈
dup2_x2             复制栈顶部两个字长的内容,然后将复制内容及原来弹出的四个字长的内容压入栈
swap             交换栈顶部两个字长内容
类型转换
i2l             把int类型的数据转化为long类型
i2f             把int类型的数据转化为float类型
i2d             把int类型的数据转化为double类型
l2i             把long类型的数据转化为int类型
l2f             把long类型的数据转化为float类型
l2d             把long类型的数据转化为double类型
f2i             把float类型的数据转化为int类型
f2l             把float类型的数据转化为long类型
f2d             把float类型的数据转化为double类型
d2i             把double类型的数据转化为int类型
d2l             把double类型的数据转化为long类型
d2f             把double类型的数据转化为float类型
i2b             把int类型的数据转化为byte类型
i2c             把int类型的数据转化为char类型
i2s             把int类型的数据转化为short类型
整数运算
iadd             执行int类型的加法
ladd             执行long类型的加法
isub             执行int类型的减法
lsub             执行long类型的减法
imul             执行int类型的乘法
lmul             执行long类型的乘法
idiv             执行int类型的除法
ldiv             执行long类型的除法

 

irem             计算int类型除法的余数
lrem             计算long类型除法的余数
ineg             对一个int类型值进行取反操作
lneg             对一个long类型值进行取反操作
iinc             把一个常量值加到一个int类型的局部变量上
逻辑运算
移位操作
ishl             执行int类型的向左移位操作
lshl             执行long类型的向左移位操作
ishr             执行int类型的向右移位操作
lshr             执行long类型的向右移位操作
iushr             执行int类型的向右逻辑移位操作
lushr             执行long类型的向右逻辑移位操作
按位布尔运算
iand             对int类型值进行“逻辑与”操作
land             对long类型值进行“逻辑与”操作
ior             对int类型值进行“逻辑或”操作
lor             对long类型值进行“逻辑或”操作
ixor             对int类型值进行“逻辑异或”操作
lxor             对long类型值进行“逻辑异或”操作
浮点运算
fadd             执行float类型的加法
dadd             执行double类型的加法
fsub             执行float类型的减法
dsub             执行double类型的减法
fmul             执行float类型的乘法
dmul             执行double类型的乘法
fdiv             执行float类型的除法
ddiv             执行double类型的除法
frem             计算float类型除法的余数
drem             计算double类型除法的余数
fneg             将一个float类型的数值取反
dneg             将一个double类型的数值取反

 

 

对象和数组
对象操作指令
new             创建一个新对象
checkcast         确定对象为所给定的类型
getfield         从对象中获取字段
putfield         设置对象中字段的值
getstatic         从类中获取静态字段
putstatic         设置类中静态字段的值
instanceof         判断对象是否为给定的类型
数组操作指令
newarray         分配数据成员类型为基本上数据类型的新数组
anewarray         分配数据成员类型为引用类型的新数组
arraylength         获取数组长度
multianewarray         分配新的多维数组
控制流
条件分支指令
ifeq             如果等于0,则跳转
ifne             如果不等于0,则跳转
iflt             如果小于0,则跳转
ifge             如果大于等于0,则跳转
ifgt             如果大于0,则跳转
ifle             如果小于等于0,则跳转
if_icmpcq         如果两个int值相等,则跳转
if_icmpne         如果两个int类型值不相等,则跳转
if_icmplt         如果一个int类型值小于另外一个int类型值,则跳转
if_icmpge         如果一个int类型值大于或者等于另外一个int类型值,则跳转
if_icmpgt         如果一个int类型值大于另外一个int类型值,则跳转
if_icmple         如果一个int类型值小于或者等于另外一个int类型值,则跳转
ifnull             如果等于null,则跳转
ifnonnull         如果不等于null,则跳转
if_acmpeq         如果两个对象引用相等,则跳转
if_acmpnc         如果两个对象引用不相等,则跳转
比较指令
lcmp             比较long类型值
fcmpl             比较float类型值(当遇到NaN时,返回-1)
fcmpg             比较float类型值(当遇到NaN时,返回1)
dcmpl             比较double类型值(当遇到NaN时,返回-1)
dcmpg             比较double类型值(当遇到NaN时,返回1)

 

无条件转移指令
goto             无条件跳转
goto_w             无条件跳转(宽索引)
表跳转指令
tableswitch         通过索引访问跳转表,并跳转
lookupswitch         通过键值匹配访问跳转表,并执行跳转操作
异常
athrow             抛出异常或错误
finally子句
jsr             跳转到子例程
jsr_w             跳转到子例程(宽索引)
rct             从子例程返回
方法调用与返回
方法调用指令
invokcvirtual         运行时按照对象的类来调用实例方法
invokespecial         根据编译时类型来调用实例方法
invokestatic         调用类(静态)方法
invokcinterface         调用接口方法
方法返回指令
ireturn             从方法中返回int类型的数据
lreturn             从方法中返回long类型的数据
freturn             从方法中返回float类型的数据
dreturn             从方法中返回double类型的数据
areturn             从方法中返回引用类型的数据
return             从方法中返回,返回值为void
线程同步
montiorenter         进入并获取对象监视器
monitorexit         释放并退出对象监视器



***********************************************************************
JVM指令助记符
变量到操作数栈:iload,iload_<n>,lload,lload_<n>,fload,fload_<n>,dload,dload_<n>,aload,aload_<n>
操作数栈到变量:istore,istore_<n>,lstore,lstore_<n>,fstore,fstore_<n>,dstore,dstor_<n>,astore,astore_<n>
常数到操作数栈:bipush,sipush,ldc,ldc_w,ldc2_w,aconst_null,iconst_ml,iconst_<i>,lconst_<l>,fconst_<f>,dconst_<d>
加:iadd,ladd,fadd,dadd
减:isub,lsub,fsub,dsub
乘:imul,lmul,fmul,dmul
除:idiv,ldiv,fdiv,ddiv
余数:irem,lrem,frem,drem
取负:ineg,lneg,fneg,dneg
移位:ishl,lshr,iushr,lshl,lshr,lushr
按位或:ior,lor
按位与:iand,land
按位异或:ixor,lxor
类型转换:i2l,i2f,i2d,l2f,l2d,f2d(放宽数值转换)
           i2b,i2c,i2s,l2i,f2i,f2l,d2i,d2l,d2f(缩窄数值转换)

创建类实便:new
创建新数组:newarray,anewarray,multianwarray
访问类的域和类实例域:getfield,putfield,getstatic,putstatic
把数据装载到操作数栈:baload,caload,saload,iaload,laload,faload,daload,aaload
从操作数栈存存储到数组:bastore,castore,sastore,iastore,lastore,fastore,dastore,aastore
获取数组长度:arraylength
检相类实例或数组属性:instanceof,checkcast
操作数栈管理:pop,pop2,dup,dup2,dup_xl,dup2_xl,dup_x2,dup2_x2,swap
有条件转移:ifeq,iflt,ifle,ifne,ifgt,ifge,ifnull,ifnonnull,if_icmpeq,if_icmpene,
             if_icmplt,if_icmpgt,if_icmple,if_icmpge,if_acmpeq,if_acmpne,lcmp,fcmpl
     fcmpg,dcmpl,dcmpg
复合条件转移:tableswitch,lookupswitch
无条件转移:goto,goto_w,jsr,jsr_w,ret
调度对象的实便方法:invokevirtual
调用由接口实现的方法:invokeinterface
调用需要特殊处理的实例方法:invokespecial
调用命名类中的静态方法:invokestatic
方法返回:ireturn,lreturn,freturn,dreturn,areturn,return
异常:athrow
finally关键字的实现使用:jsr,jsr_w,ret

分享到:
评论

相关推荐

    jvm-java字节码规则.pdf

    在`jvm-java字节码规则.pdf`文档中,描述了JVM执行这些指令的一些基本规则。 1. **常量压入栈的指令**: - `aconst_null`:将null对象引用压入操作数栈,通常用于表示Java对象的空引用。 - `iconst_m1`到`iconst_...

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

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

    Java字节码加密工具

    Java字节码加密工具是一种用于保护Java应用程序源代码安全的工具。在软件开发过程中,源代码是开发者的心血结晶,包含了许多重要的商业逻辑和技术细节。然而,Java的字节码(.class文件)虽然相对于源代码(.java...

    该项目主要是JAVA字节码的学习项目.zip

    Java字节码是Java编程语言的核心组成部分,它在Java虚拟机(JVM)上运行,使得Java具有跨平台的能力。这个学习项目显然旨在深入理解Java字节码的工作原理及其在实际开发中的应用。以下是关于Java字节码的详细知识点...

    Java字节码揭秘

    ### Java字节码揭秘 #### 一、Java体系结构概览 Java体系结构主要由以下几个部分构成: 1. **Java Language(Java语言)**: 定义了语法和语义规则,用于编写Java程序。 2. **Java Class(Java类)**: 是Java程序...

    cglib,字节码生成库是生成和转换Java字节码的高级API。它被aop、测试、数据访问框架用来生成动态代理对象和拦截字段访问。.zip

    **CGlib:高级Java字节码生成库** CGlib(Code Generation Library)是一个强大的高性能的代码生成库,它主要用于在运行期扩展Java类与实现Java接口。这个库最初由Evan Schooler创建,后来成为Apache软件基金会的一...

    发布新程序:java 字节码查看器

    标题 "发布新程序:java 字节码查看器" 暗示了这是一个关于Java字节码分析工具的项目。在Java编程中,字节码是Java虚拟机(JVM)执行的中间代码,它是由Java编译器将源代码编译成的。这个程序可能允许开发者查看并...

    huntbugs,Java字节码静态分析器.zip

    《猎蝽:Java字节码静态分析器的深度探索》 在编程领域,代码质量是决定软件稳定性与可维护性的关键因素。为了确保代码的健壮性,开发人员需要进行多方面的检查,其中就包括静态代码分析。"猎蝽(HuntBugs)"是一款...

    基于Java字节码的Java程序加密工具设计源码

    该项目是一款基于Java字节码的Java程序加密工具,源码包含40个文件,涵盖20个Java源代码文件、6个XML配置文件、5个Git忽略规则文件、3个JavaScript脚本文件、1个CSS样式表文件、1个Markdown文档、1个YAML配置文件、1...

    java习题 字节码文件

    ### Java习题:字节码文件相关知识点 #### 一、选择题解析 ...以上解析涵盖了给定的Java习题中涉及的主要知识点,包括字节码文件、Java Applet的编写、变量的初始化、标识符规则以及`switch`语句的使用等方面。

    Android-HiBeaver是一个用于进行Android字节码插桩的Gradle插件

    ASM是一个Java字节码操控和分析框架,它可以直接生成和分析类的二进制字节码,是许多Java和Android插桩工具的基础。通过这个插件,开发者无需深入理解复杂的字节码操作,就能实现AOP中的切面、通知等概念。 Gradle...

    ASM 字节码修改工具中文帮助手册

    - **版本信息**: ASM 4.0 是一个 Java 字节码操作和分析框架,由 Eric Bruneton 开发并维护,版权归属 Eric Bruneton(2007-2011)。 - **许可证**: 使用者可自由地重新发布和使用该文档的源码(LYX 格式)或编译后...

    基于Java字节码技术的高性能hp-reflect反射工具设计源码

    hp-reflect 是一款基于Java字节码技术的高效反射工具,其设计源码包含31个文件,其中Java源文件21个,辅助文件包括备份文件、Git忽略规则、许可证、文档、XML配置等。该工具通过动态生成access class,实现高效的...

    探索Java虚拟机的心脏:字节码执行全解析

    Java字节码的执行过程是理解Java运行机制的核心。下面我们将详细探讨这一过程。 ##### 编译 Java源代码通过`javac`编译器被编译成字节码(`.class`文件)。编译器将高级语言转换为低级的中间表示形式——字节码。...

    java实现dex文件方法字节码隐藏

    Java中的Dex文件是Dalvik虚拟机执行的字节码格式,主要用于Android应用程序。当我们谈论“java实现dex文件方法字节码隐藏”时,我们实际上是在讨论如何在Android应用的编译或打包过程中,对特定的方法进行混淆或者...

    Java Classloading Mechanism : ClassLoader & ASM & 动态字节码增强

    接下来,我们引入ASM库,这是一个强大的Java字节码操控和分析框架。ASM允许开发者在运行时动态生成和修改类。通过ASM,我们可以: - 创建全新的类、接口或继承已有类的子类。 - 修改已有的类,添加、删除或修改方法...

    java扰码器

    这些功能使得Java字节码变得难以理解和逆向工程,从而提高代码的安全性。 1. **混淆**:混淆是Java扰码器的核心功能。它通过重命名类、方法和变量,使它们的名称变得晦涩难懂,从而增加反编译的难度。例如,将`...

    java虚拟机源码-jvm_based_compiler:该程序实现了递归下降解析器,将源代码转换为字节码,以便生成的字节码可以在Java虚拟

    Java虚拟机(JVM)是Java程序运行的基础,它是一个抽象的计算机,负责执行Java字节码。在本文中,我们将深入探讨一个基于JVM的编译器项目,该编译器使用递归下降解析器将源代码转换为Java字节码。这个开源项目对于...

    “字节码插桩“ Demo.rar

    字节码插桩的核心原理是基于Java字节码(Class文件)的操作。在Android中,Dalvik和ART虚拟机使用dex格式的字节码。当应用编译完成后,Class文件会被转换成dex格式。插桩过程就是在这个转换过程中,通过分析和修改...

Global site tag (gtag.js) - Google Analytics