您当前的位置:首页 > 电脑百科 > 程序开发 > 语言 > JAVA

Java反汇编指令全集

时间:2019-08-02 14:40:28  来源:  作者:

栈和局部变量操作

将常量压入栈的指令

  • 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_,lload,lload_,fload,fload_,dload,dload_,aload,aload_

操作数栈到变量:istore,istore_,lstore,lstore_,fstore,fstore_,dstore,dstor_,astore,astore_

常数到操作数栈:bipush,sipush,ldc,ldc_w,ldc2_w,aconst_null,iconst_ml,iconst_,lconst_,fconst_,dconst_

加: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

有需要编程视频的可以私信小七"学习"哦!需要其他资源的也可以私聊小七的!

Java反汇编指令全集

 



Tags:Java 反汇编指令   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
栈和局部变量操作将常量压入栈的指令 aconst_null 将null对象引用压入栈 iconst_m1 将int类型常量-1压入栈 iconst_0 将int类型常量0压入栈 iconst_1 将int类型常量1压入栈 ...【详细内容】
2019-08-02  Tags: Java 反汇编指令  点击:(243)  评论:(0)  加入收藏
▌简易百科推荐
面向对象的特征之一封装 面向对象的特征之二继承 方法重写(override/overWrite) 方法的重载(overload)和重写(override)的区别: 面向对象特征之三:多态 Instanceof关键字...【详细内容】
2021-12-28  顶顶架构师    Tags:面向对象   点击:(2)  评论:(0)  加入收藏
一、Redis使用过程中一些小的注意点1、不要把Redis当成数据库来使用二、Arrays.asList常见失误需求:把数组转成list集合去处理。方法:Arrays.asList 或者 Java8的stream流式处...【详细内容】
2021-12-27  CF07    Tags:Java   点击:(3)  评论:(0)  加入收藏
文章目录 如何理解面向对象编程? JDK 和 JRE 有什么区别? 如何理解Java中封装,继承、多态特性? 如何理解Java中的字节码对象? 你是如何理解Java中的泛型的? 说说泛型应用...【详细内容】
2021-12-24  Java架构师之路    Tags:JAVA   点击:(5)  评论:(0)  加入收藏
大家好!我是老码农,一个喜欢技术、爱分享的同学,从今天开始和大家持续分享JVM调优方面的经验。JVM调优是个大话题,涉及的知识点很庞大 Java内存模型 垃圾回收机制 各种工具使用 ...【详细内容】
2021-12-23  小码匠和老码农    Tags:JVM调优   点击:(12)  评论:(0)  加入收藏
前言JDBC访问Postgresql的jsonb类型字段当然可以使用Postgresql jdbc驱动中提供的PGobject,但是这样在需要兼容多种数据库的系统开发中显得不那么通用,需要特殊处理。本文介绍...【详细内容】
2021-12-23  dingle    Tags:JDBC   点击:(13)  评论:(0)  加入收藏
Java与Lua相互调用案例比较少,因此项目使用需要做详细的性能测试,本内容只做粗略测试。目前已完成初版Lua-Java调用框架开发,后期有时间准备把框架进行抽象,并开源出来,感兴趣的...【详细内容】
2021-12-23  JAVA小白    Tags:Java   点击:(11)  评论:(0)  加入收藏
Java从版本5开始,在 java.util.concurrent.locks包内给我们提供了除了synchronized关键字以外的几个新的锁功能的实现,ReentrantLock就是其中的一个。但是这并不意味着我们可...【详细内容】
2021-12-17  小西学JAVA    Tags:JAVA并发   点击:(11)  评论:(0)  加入收藏
一、概述final是Java关键字中最常见之一,表示“最终的,不可更改”之意,在Java中也正是这个意思。有final修饰的内容,就会变得与众不同,它们会变成终极存在,其内容成为固定的存在。...【详细内容】
2021-12-15  唯一浩哥    Tags:Java基础   点击:(17)  评论:(0)  加入收藏
1、问题描述关于java中的日志管理logback,去年写过关于logback介绍的文章,这次项目中又优化了下,记录下,希望能帮到需要的朋友。2、解决方案这次其实是碰到了一个问题,一般的情况...【详细内容】
2021-12-15  软件老王    Tags:logback   点击:(19)  评论:(0)  加入收藏
本篇文章我们以AtomicInteger为例子,主要讲解下CAS(Compare And Swap)功能是如何在AtomicInteger中使用的,以及提供CAS功能的Unsafe对象。我们先从一个例子开始吧。假设现在我们...【详细内容】
2021-12-14  小西学JAVA    Tags:JAVA   点击:(22)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条