java 字节码 指令集
有时候为了能理解JVM对程序所做的优化等,需要查看程序的字节码,因此知道了解一些常见的指令集很重要!
|
指令码 |
助记符 |
说明 |
|
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 |
将单字节的常量值(-128~127)推送至栈顶 |
|
0x11 |
sipush |
将一个短整型常量值(-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类型的)或两个数值弹出(其它) |
|
0x59 |
dup |
复制栈顶数值并将复制值压入栈顶 |
|
0x5a |
dup_x1 |
复制栈顶数值并将两个复制值压入栈顶 |
|
0x5b |
dup_x2 |
复制栈顶数值并将三个(或两个)复制值压入栈顶 |
|
0x5c |
dup2 |
复制栈顶一个(long或double类型的)或两个(其它)数值并将复制值压入栈顶 |
|
0x5d |
dup2_x1 |
<待补充> |
|
0x5e |
dup2_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 |
将指定int型变量增加指定值(i++, i--, i+=2) |
|
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下一条指令地址压入栈顶 |
java 字节码 指令集的更多相关文章
- java字节码指令集
字节码指令集 Java虚拟机的指令由一个字节长度的.代表着某种特定操作含义的操作码(Opcode)以及跟随其后的零至多个代表此操作所需参数的操作数(Operands)所构成. 对于大部分为与数据类型相 ...
- java 字节码 指令集 汇编(转)
https://blog.csdn.net/github_35983163/article/details/52945845 网上找的没有指令码这列 自己把它加上 更方便查阅 指令从0x00-0xc ...
- java 字节码指令集
This is a list of the instructions that make up the Java bytecode, an abstract machine language that ...
- Java虚拟机--字节码指令集
1. 字节码指令集简介: Java虚拟机的指令由一个字节长度的,代表着某种特定操作含义的操作码(Opcode)以及跟随其后的零至多个代表此操作所需参数的操作数(Operands)所构成.虚拟机中许多指 ...
- [三] java虚拟机 JVM字节码 指令集 bytecode 操作码 指令分类用法 助记符
说明,本文的目的在于从宏观逻辑上介绍清楚绝大多数的字节码指令的含义以及分类 只要认真阅读本文必然能够对字节码指令集有所了解 如果需要了解清楚每一个指令的具体详尽用法,请参阅虚拟机规范 指令简介 计算机 ...
- Java字节码操纵框架ASM小试
本文主要内容: ASM是什么 JVM指令 Java字节码文件 ASM编程模型 ASM示例 参考资料汇总 JVM详细指令 ASM是什么 ASM是一个Java字节码操纵框架,它能被用来动态生成类或者增强既 ...
- Java:从面试题“i++和++i哪个效率高?"开始学习java字节码
今天看到一道面试题,i++和++i的效率谁高谁低. 面试题的答案是++i要高一点. 我在网上搜了一圈儿,发现很多回答也都是同一个结论. 如果早个几年,我也会认同这个看法,但现在我负责任的说,这个结论是 ...
- 从 HelloWorld 看 Java 字节码文件结构
很多时候,我们都是从代码层面去学习如何编程,却很少去看看一个个 Java 代码背后到底是什么.今天就让我们从一个最简单的 Hello World 开始看一看 Java 的类文件结构. 在开始之前,我们 ...
- Java字节码里的invoke操作&&编译时的静态绑定与动态绑定
一个一直运行正常的应用突然无法运行了.在类库被更新之后,返回下面的错误. Exception in thread "main" java.lang.NoSuchMethodErro ...
随机推荐
- PHP一句话后门过狗姿势万千之理论篇
写在前面: 过狗相关的资料网上也是有很多,所以在我接下来的文章中,可能观点或者举例可能会与网上部分雷同,或者表述不够全面. 但是我只能说,我所传达给大家的信息,是我目前所掌握或者了解的,不能保证所有人 ...
- Big Data Mindmap
- 一行命令杀掉defunct进程
一行命令杀掉defunct进程 今天在杀掉defunc过程中一直搞不完,索性写一行命令,注意先看懂谨慎使用 ps -ef|grep defunct|awk '{print " ps -ef| ...
- C++_pthread read-write lock_读写锁_visual studio 2015下配置
pthread下载地址:https://sourceware.org/pthreads-win32/ 1. 项目->属性->VC++目录 包含目录里添加:pthread所在路径\pthre ...
- Android(java)学习笔记172:服务(service)之绑定服务调用服务里面的方法 (采用接口隐藏代码内部实现)
1. 接口 接口可以隐藏代码内部的细节,只暴露程序员想暴露的方法 2. 利用上面的思想优化之前的案例:服务(service)之绑定服务调用服务里面的方法,如下: (1)这里MainActivity.j ...
- uva11925 Generating Permutations
逆序做,逆序输出 紫书上的描述有点问题 感觉很经典 ans.push_back(2); a.insert(a.begin(),a[n-1]); a.erase(a.end()-1); a.push_b ...
- JAVA自定义栈
public class Stack{ int[] data; int maxSize; int top; public Stack(int maxSize) { this.maxSize=maxSi ...
- Linux内核网络数据包处理流程
Linux内核网络数据包处理流程 from kernel-4.9: 0. Linux内核网络数据包处理流程 - 网络硬件 网卡工作在物理层和数据链路层,主要由PHY/MAC芯片.Tx/Rx FIFO. ...
- node.js从入门到放弃(一)
以下内容全是我个人理解写出,如有不对,请立刻练习本人进行更改.以免被刚入门的被我带入坑里. —node是什么?我想大家应该都知道. node是前端未来干掉后端的一种语言,是用JavaScript来编写 ...
- canvas之刮刮乐
效果图: 代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...