JVM 字节码指令表

Stella981
• 阅读 806

字节码

助记符

指令含义

0x00

nop

什么都不做

0x01

aconst_null

将 null 推送至栈顶

0x02

iconst_m1

将 int 型 -1 推送至栈顶

0x03

iconst_0

将 int 型 0 推送至栈顶

0x04

iconst_1

将 int 型 1 推送至栈顶

0x05

iconst_2

将 int 型 2 推送至栈顶

0x06

iconst_3

将 int 型 3 推送至栈顶

0x07

iconst_4

将 int 型 4 推送至栈顶

0x08

iconst_5

将 int 型 5 推送至栈顶

0x09

lconst_0

将 long 型 0 推送至栈顶

0x0a

lconst_1

将 long 型 1 推送至栈顶

0x0b

fconst_0

将 float 型 0 推送至栈顶

0x0c

fconst_1

将 float 型 1 推送至栈顶

0x0d

fconst_2

将 float 型 2 推送至栈顶

0x0e

dconst_0

将 double 型 0 推送至栈顶

0x0f

dconst_1

将 double 型 1 推送至栈顶

0x10

bipush

将单字节的常量值(Byte.MIN_VALUE ~ Byte.MAX_VALUE,即 -128~127)推送至栈顶

0x11

sipush

将短整型的常量值(Short.MIN_VALUE ~ Short.MAX_VALUE,即 -32768~32767)推送至栈顶

0x12

ldc

将 int、float 或 String 型常量值从常量池中推送至栈顶

0x13

ldc_w

将 int、float 或 String 型常量值从常量池中推送至栈顶(宽索引)

0x14

ldc2_w

将 long 或 double 型常量值从常量池中推送至栈顶(宽索引)

0x15

iload

将指定的 int 型局部变量推送至栈顶

0x16

lload

将指定的 long 型局部变量推送至栈顶

0x17

fload

将指定的 float 型局部变量推送至栈顶

0x18

dload

将指定的 double 型局部变量推送至栈顶

0x19

aload

将指定的 引用 型局部变量推送至栈顶

0x1a

iload_0

将第一个 int 型局部变量推送至栈顶

0x1b

iload_1

将第二个 int 型局部变量推送至栈顶

0x1c

iload_2

将第三个 int 型局部变量推送至栈顶

0x1d

iload_3

将第四个 int 型局部变量推送至栈顶

0x1e

lload_0

将第一个 long 型局部变量推送至栈顶

0x1f

lload_1

将第二个 long 型局部变量推送至栈顶

0x20

lload_2

将第三个 long 型局部变量推送至栈顶

0x21

lload_3

将第四个 long 型局部变量推送至栈顶

0x22

fload_0

将第一个 float 型局部变量推送至栈顶

0x23

fload_1

将第二个 float 型局部变量推送至栈顶

0x24

fload_2

将第三个 float 型局部变量推送至栈顶

0x25

fload_3

将第四个 float 型局部变量推送至栈顶

0x26

dload_0

将第一个 double 型局部变量推送至栈顶

0x27

dload_1

将第二个 double 型局部变量推送至栈顶

0x28

dload_2

将第三个 double 型局部变量推送至栈顶

0x29

dload_3

将第四个 double 型局部变量推送至栈顶

0x2a

aload_0

将第一个 引用 型局部变量推送至栈顶

0x2b

aload_1

将第二个 引用 型局部变量推送至栈顶

0x2c

aload_2

将第三个 引用 型局部变量推送至栈顶

0x2d

aload_3

将第四个 引用 型局部变量推送至栈顶

0x2e

iaload

将 int 型数组指定索引的值推送至栈顶

0x2f

laload

将 long 型数组指定索引的值推送至栈顶

0x30

faload

将 float 型数组指定索引的值推送至栈顶

0x31

daload

将 double 型数组指定索引的值推送至栈顶

0x32

aaload

将 引用 型数组指定索引的值推送至栈顶

0x33

baload

将 boolean 或 byte 型数组指定索引的值推送至栈顶

0x34

caload

将 char 型数组指定索引的值推送至栈顶

0x35

saload

将 short 型数组指定索引的值推送至栈顶

0x36

istore

将栈顶 int 型数值存入指定局部变量

0x37

lstore

将栈顶 long 型数值存入指定局部变量

0x38

fstore

将栈顶 float 型数值存入指定局部变量

0x39

dstore

将栈顶 double 型数值存入指定局部变量

0x3a

astore

将栈顶 引用 型数值存入指定局部变量

0x3b

istore_0

将栈顶 int 型数值存入第一个局部变量

0x3c

istore_1

将栈顶 int 型数值存入第二个局部变量

0x3d

istore_2

将栈顶 int 型数值存入第三个局部变量

0x3e

istore_3

将栈顶 int 型数值存入第四个局部变量

0x3f

lstore_0

将栈顶 long 型数值存入第一个局部变量

0x40

lstore_1

将栈顶 long 型数值存入第二个局部变量

0x41

lstore_2

将栈顶 long 型数值存入第三个局部变量

0x42

lstore_3

将栈顶 long 型数值存入第四个局部变量

0x43

fstore_0

将栈顶 float 型数值存入第一个局部变量

0x44

fstore_1

将栈顶 float 型数值存入第二个局部变量

0x45

fstore_2

将栈顶 float 型数值存入第三个局部变量

0x46

fstore_3

将栈顶 float 型数值存入第四个局部变量

0x47

dstore_0

将栈顶 double 型数值存入第一个局部变量

0x48

dstore_1

将栈顶 double 型数值存入第二个局部变量

0x49

dstore_2

将栈顶 double 型数值存入第三个局部变量

0x4a

dstore_3

将栈顶 double 型数值存入第四个局部变量

0x4b

astore_0

将栈顶 引用 型数值存入第一个局部变量

0x4c

astore_1

将栈顶 引用 型数值存入第二个局部变量

0x4d

astore_2

将栈顶 引用 型数值存入第三个局部变量

0x4e

astore_3

将栈顶 引用 型数值存入第四个局部变量

0x4f

iastore

将栈顶 int 型数值存入指定数组的指定索引位置

0x50

lastore

将栈顶 long 型数值存入指定数组的指定索引位置

0x51

fastore

将栈顶 float 型数值存入指定数组的指定索引位置

0x52

dastore

将栈顶 double 型数值存入指定数组的指定索引位置

0x53

aastore

将栈顶 引用 型数值存入指定数组的指定索引位置

0x54

bastore

将栈顶 boolean 或 byte 型数值存入指定数组的指定索引位置

0x55

castore

将栈顶 char 型数值存入指定数组的指定索引位置

0x56

sastore

将栈顶 short 型数值存入指定数组的指定索引位置

0x57

pop

将栈顶数值弹出(数值不能是 long 或 double 类型的)

0x58

pop2

将栈顶的一个(对于 long 或 double 类型)或两个数值(对于非 long 或 double 的其他类型)弹出

0x59

dup

复制栈顶数值并将复制值压入栈顶

0x5a

dup_x1

复制栈顶数值并将两个复制值压入栈顶

0x5b

dup_x2

复制栈顶数值并将三个(或两个)复制值压入栈顶

0x5c

dup2

复制栈顶一个(对于 long 或 double 类型)或两个数值(对于非 long 或 double 的其他类型)并将复制值压入栈顶

0x5d

dup2_x1

dup_x1 指令的双倍版本

0x5e

dup2_x2

dup_x2 指令的双倍版本

0x5f

swap

将栈最顶端的两个数值互换(数值不能是 long 或 double 类型)

0x60

iadd

将栈顶两 int 型数值相加并将结果压入栈顶

0x61

ladd

将栈顶两 long 型数值相加并将结果压入栈顶

0x62

fadd

将栈顶两 float 型数值相加并将结果压入栈顶

0x63

dadd

将栈顶两 double 型数值相加并将结果压入栈顶

0x64

isub

将栈顶两 int 型数值相减并将结果压入栈顶

0x65

lsub

将栈顶两 long 型数值相减并将结果压入栈顶

0x66

fsub

将栈顶两 float 型数值相减并将结果压入栈顶

0x67

dsub

将栈顶两 double 型数值相减并将结果压入栈顶

0x68

imul

将栈顶两 int 型数值相乘并将结果压入栈顶

0x69

lmul

将栈顶两 long 型数值相乘并将结果压入栈顶

0x6a

fmul

将栈顶两 float 型数值相乘并将结果压入栈顶

0x6b

dmul

将栈顶两 double 型数值相乘并将结果压入栈顶

0x6c

idiv

将栈顶两 int 型数值相除并将结果压入栈顶

0x6d

ldiv

将栈顶两 long 型数值相除并将结果压入栈顶

0x6e

fdiv

将栈顶两 float 型数值相除并将结果压入栈顶

0x6f

ddiv

将栈顶两 double 型数值相除并将结果压入栈顶

0x70

irem

将栈顶两 int 型数值作取模运算并将结果压入栈顶

0x71

lrem

将栈顶两 long 型数值作取模运算并将结果压入栈顶

0x72

frem

将栈顶两 float 型数值作取模运算并将结果压入栈顶

0x73

drem

将栈顶两 double 型数值作取模运算并将结果压入栈顶

0x74

ineg

将栈顶两 int 型数值取负并将结果压入栈顶

0x75

lneg

将栈顶两 long 型数值取负并将结果压入栈顶

0x76

fneg

将栈顶两 float 型数值取负并将结果压入栈顶

0x77

dneg

将栈顶两 double 型数值取负并将结果压入栈顶

0x78

ishl

将 int 型数值左移指定位数并将结果压入栈顶

0x79

lshl

将 long 型数值左移指定位数并将结果压入栈顶

0x7a

ishr

将 int 型数值右(带符号)移指定位数并将结果压入栈顶

0x7b

lshr

将 long 型数值右(带符号)移指定位数并将结果压入栈顶

0x7c

iushr

将 int 型数值右(无符号)移指定位数并将结果压入栈顶

0x7d

lushr

将 long 型数值右(无符号)移指定位数并将结果压入栈顶

0x7e

iand

将栈顶两 int 型数值作“按位与”并将结果压入栈顶

0x7f

land

将栈顶两 long 型数值作“按位与”并将结果压入栈顶

0x80

ior

将栈顶两 int 型数值作“按位或”并将结果压入栈顶

0x81

lor

将栈顶两 long 型数值作“按位或”并将结果压入栈顶

0x82

ixor

将栈顶两 int 型数值作“按位异或”并将结果压入栈顶

0x83

lxor

将栈顶两 long 型数值作“按位异或”并将结果压入栈顶

0x84

iinc M N

(M 为非负整数,N 为整数)将局部变量数组的第 M 个单元中的 int 值增加 N,常用于 for 循环中自增量的更新

0x85

i2l

将栈顶 int 型数值强制转换成 long 型数值,并将结果压入栈顶

0x86

i2f

将栈顶 int 型数值强制转换成 float 型数值,并将结果压入栈顶

0x87

i2d

将栈顶 int 型数值强制转换成 double 型数值,并将结果压入栈顶

0x88

l2i

将栈顶 long 型数值强制转换成 int 型数值,并将结果压入栈顶

0x89

l2f

将栈顶 long 型数值强制转换成 float 型数值,并将结果压入栈顶

0x8a

l2d

将栈顶 long 型数值强制转换成 double 型数值,并将结果压入栈顶

0x8b

f2i

将栈顶 float 型数值强制转换成 int 型数值,并将结果压入栈顶

0x8c

f2l

将栈顶 float 型数值强制转换成 long 型数值,并将结果压入栈顶

0x8d

f2d

将栈顶 float 型数值强制转换成 double 型数值,并将结果压入栈顶

0x8e

d2i

将栈顶 double 型数值强制转换成 int 型数值,并将结果压入栈顶

0x8f

d2l

将栈顶 double 型数值强制转换成 long 型数值,并将结果压入栈顶

0x90

d2f

将栈顶 double 型数值强制转换成 float 型数值,并将结果压入栈顶

0x91

i2b

将栈顶 int 型数值强制转换成 byte 型数值,并将结果压入栈顶

0x92

i2c

将栈顶 int 型数值强制转换成 char 型数值,并将结果压入栈顶

0x93

i2s

将栈顶 int 型数值强制转换成 short 型数值,并将结果压入栈顶

0x94

lcmp

比较栈顶两 long 型数值的大小,并将结果(1、0 或 -1)压入栈顶

0x95

fcmpl

比较栈顶两 float 型数值的大小,并将结果(1、0 或 -1)压入栈顶 ;当其中一个数值为 “NaN” 时,将 -1 压入栈顶

0x96

fcmpg

比较栈顶两 float 型数值的大小,并将结果(1、0 或 -1)压入栈顶 ;当其中一个数值为 “NaN” 时,将 1 压入栈顶

0x97

dcmpl

比较栈顶两 double 型数值的大小,并将结果(1、0 或 -1)压入栈顶 ;当其中一个数值为 “NaN” 时,将 -1 压入栈顶

0x98

dcmpg

比较栈顶两 double 型数值的大小,并将结果(1、0 或 -1)压入栈顶 ;当其中一个数值为 “NaN” 时,将 1 压入栈顶

0x99

ifeq

当栈顶 int 型数值等于 0 时跳转

0x9a

ifne

当栈顶 int 型数值不等于 0 时跳转

0x9b

iflt

当栈顶 int 型数值小于 0 时跳转

0x9c

ifge

当栈顶 int 型数值大于或等于 0 时跳转

0x9d

ifgt

当栈顶 int 型数值大于 0 时跳转

0x9e

ifle

当栈顶 int 型数值小于或等于 0 时跳转

0x9f

if_icmpeq

比较栈顶两 int 型数值的大小,当结果等于 0 时跳转

0xa0

if_icmpne

比较栈顶两 int 型数值的大小,当结果不等于 0 时跳转

0xa1

if_icmplt

比较栈顶两 int 型数值的大小,当结果小于 0 时跳转

0xa2

if_icmpge

比较栈顶两 int 型数值的大小,当结果大于或等于 0 时跳转

0xa3

if_icmpgt

比较栈顶两 int 型数值的大小,当结果大于 0 时跳转

0xa4

if_icmple

比较栈顶两 int 型数值的大小,当结果小于或等于 0 时跳转

0xa5

if_acmpeq

比较栈顶两 引用 型数值,当结果相等时跳转

0xa6

if_acmpne

比较栈顶两 引用 型数值,当结果不相等时跳转

0xa7

goto

无条件跳转

0xa8

jsr

跳转至指定的 16 位 offset 位置,并将 jsr 的下一条指令地址压入栈顶

0xa9

ret

返回至局部变量指定的 index 的指令位置(一般与 jsr 或 jsr_w 联合使用)

0xaa

tableswitch

用于 switch 条件跳转,case 值连续(可变长度指令)

0xab

lookupswitch

用于 switch 条件跳转,case 值不连续(可变长度指令)

0xac

ireturn

从当前方法返回 int

0xad

lreturn

从当前方法返回 long

0xae

freturn

从当前方法返回 float

0xaf

dreturn

从当前方法返回 double

0xb0

areturn

从当前方法返回对象引用

0xb1

return

从当前方法返回 void

0xb2

getstatic

获取指定类的静态字段,并将其压入栈顶

0xb3

putstatic

为指定类的静态字段赋值

0xb4

getfield

获取指定类的实例字段,并将其压入栈顶

0xb5

putfield

为指定类的实例字段赋值

0xb6

invokevirtual

调用实例方法

0xb7

invokespecial

调用超类构造方法,实例初始化方法,私有方法

0xb8

invokestatic

调用静态方法

0xb9

invokeinterface

调用接口方法

0xba

--

无此指令

0xbb

new

创建一个对象,并将其引用值压入栈顶

0xbc

newarray

创建一个指定的原始类型(如 int、float、char 等)的数组,并将其引用值压入栈顶

0xbd

anewarray

创建一个引用型(如类、接口、数组 等)的数组,并将其引用值压入栈顶

0xbe

arraylength

获得数组的长度值并将其压入栈顶

0xbf

athrow

将栈顶的异常抛出

0xc0

checkcast

校验类型转换,校验未通过将抛出 ClassCastException

0xc1

instanceof

校验对象是否是指定的类的实例,如果是则将 1 压入栈顶,否则将 0 压入栈顶

0xc2

monitorenter

获得对象的锁,用于同步方法或同步块

0xc3

monitorexit

释放对象的锁,用于同步方法或同步块

0xc4

wide

扩展局部变量的宽度

0xc5

multianewarray

创建指定类型和指定维度的多维数组(执行该指定时,操作数栈中必须包含各维度的长度),并将其引用值压入栈顶

0xc6

ifnull

为 null 时跳转

0xc7

ifnonnull

不为 null 时跳转

0xc8

goto_w

无条件跳转(宽索引)

0xc9

jsr_w

跳转至指定的 32 位 offset 位置,并将 jsr_w 的下一条指令地址压入栈顶

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
5个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Easter79 Easter79
3年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
11个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这