JVM指令2
0x59 dup 复制 栈顶数并将复制压入栈顶。 0x5a dup_x1 复制 栈顶数并将两个复制压入栈顶。 0x5b dup_x2 复制 栈顶数并将三个 ( 或两个 ) 复制 压入栈顶。 0x5c dup2 复制 栈顶一个 (long 或 double 类型的 ) 或两个 ( 其它 ) 数 并将复制压入栈顶。 0x5d dup
0x59 dup复制栈顶数值并将复制值压入栈顶。
0x5a dup_x1复制栈顶数值并将两个复制值压入栈顶。
0x5b dup_x2复制栈顶数值并将三个(或两个)复制值压入栈顶。
0x5c dup2复制栈顶一个(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 |
将指定 int 型变量增加指定值。 |
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 |
invokeinterfac e |
调用接口方法。 |
0xba |
invokedynamic |
调用动态链接方法1。 |
0xbb |
new |
创建一个对象,并将其引用值压入栈顶。 |
0xbc |
newarray |
创建一个指定原始类型(如 int、float、char......)的数组,并将其引用值压入栈顶。 |
0xbd |
anewarray |
创建一个引用型(如类,接口,数组)的数组,并将其引用值压 入栈顶。 |
0xbe |
arraylength |
获得数组的长度值并压入栈顶。 |
0xbf |
athrow |
将栈顶的异常抛出。 |
0xc0 |
checkcast |
检验类型转换,检验通过将抛出 ClassCastException。 |
0xc1 instanceof 检验对象是否是指定的类的实例,如果是将 1 压入栈顶,否则将0 压入栈顶。
0xc2 monitorenter获得对象的 monitor,用于同步方法或同步块。
0xc3 monitorexit释放对象的 monitor,用于同步方法或同步块。
0xc4 wide扩展访问局部变量表的索引宽度。
0xc5 multianewarray创建指定类型和指定维度的多维数组(执行该指令时,操作栈中必须包各维度的长度值),并将其引用值压入栈顶。
0xc6 ifnull为 null 时跳转。
0xc7 ifnonnull不为 null 时跳转。
0xc8 goto_w无条件跳转(宽索引)。
0xc9 jsr_w跳转至指定 32 位地址偏移量位置,并将 jsr_w 下一条指令地址压入栈顶。
保留指令
0xca breakpoint调试时的断点标志。
0xfe impdep1用于在特定硬件中使用的语言后门。
0xff impdep1用于在特定硬件中使用的语言后门。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

泰拉瑞亚怎么用指令获得物品?一、什么是泰拉瑞亚给予物品指令在泰拉瑞亚游戏中,给予物品指令是一项非常实用的功能。通过这个指令,玩家可以直接获取需要的物品,而不必费力地去打怪或者传送到某个地点。这样可以极大地节省时间,提高游戏的效率,让玩家更专注于探索和建设世界。总的来说,这个功能让游戏体验变得更加流畅和愉快。二、如何使用泰拉瑞亚给予物品指令1.打开游戏并进入游戏界面。2.按下键盘上的“Enter”键,打开聊天窗口。3.在聊天窗口中输入指令的格式:“/give[玩家名称][物品ID][物品数量]”。

我们用户们在使用这款平台的时候应该都能够了解到上面对于一些功能的多样性,我们知道一些歌曲的歌词都写的非常的不错。有时候甚至都会多听几遍,觉得其中的含义都是非常深刻的,所以我们想要去了解其中的胜意,就想要直接的复制下来当文案来使用,不过对于要使用的话,还是要学会如何去复制歌词才可以,这些操作方面我相信大家们应该都并不模式,但是在手机上面操作确实是有点难度,所以为了能够让大家们更好的了解的话,今日小编就来为你们好好的讲解上面的一些操作体验,如果你们也喜欢的话,就和小编一起来看看吧,不要错过了。

本文旨在帮助初学者快速入手Vue.js3,实现简单的选项卡切换效果。Vue.js是一个流行的JavaScript框架,可用于构建可重用的组件、轻松管理应用程序的状态和处理用户界面的交互操作。Vue.js3是该框架的最新版本,相较于之前的版本变动较大,但基本原理并未改变。在本文中,我们将使用Vue.js指令实现选项卡切换效果,目的是让读者熟悉Vue.js的

在PS复制图层快捷键中,我们可以知道使用PS的时候如果想要进行复制图层的操作,可以使用到快捷键【Ctrl+J】进行快速复制。这篇复制图层快捷键的介绍就能够告诉大家具体的操作方法,下面就是详细的内容,赶紧看看吧。PS复制图层快捷键答:【Ctrl+J】具体方法:1、在ps中打开图像,选中需要复制的图层。2、键盘同时按下【Ctrl+J】,即可完成对图层的复制。其他复制方式:1、打开图像后,按住图层,向下放【新建图层】图标移动。2、移动到该图标上后,松手。3、即可完成图层复制。

该项目为了方便开发者更快监控多个远程主机jvm,如果你的项目是Spring boot那么很方便集成,jar包引入即可,不是Spring boot也不用气馁,你可以快速自行初始化一个Spirng boot程序引入jar包即可

很多的用户们在使用电脑的时候,如果遇到一些需要复制粘贴的东西时,用鼠标复制非常麻烦,那么复制粘贴的快捷键需要如何使用呢,快来看看详细的教程吧~复制粘贴快捷键怎么用:1、复制键:Ctrl+C,选择需要复制的文字或图片,按下快捷键。2、粘贴键:Ctrl+V,在需要粘贴的位置上,直接按下快捷键就行了。

我们经常会用Excel处理多个表格数据,而设定好的表格经过复制粘贴后,原有的格式又恢复默认了,还得需要我们重新设置。其实是有方法可以使Excel复制表格保留原格式的,下面小编就给大家讲解下具体的方法。一、Ctrl键拖拉复制操作步骤:使用快捷键【Ctrl+A】全选表格内容后,将鼠标光标移至表格边缘直到出现移动光标。按住【Ctrl】键,随后拖动表格到所需位置即可完成移动。需要注意的是,这种方法只适用于单个工作表,无法在不同工作表之间进行移动。二、选择性粘贴步骤:按【Ctrl+A】快捷键全选中表格,按

在 Windows 系统中,复制的快捷键是 Ctrl+C;在苹果系统中,复制的快捷键是 Command+C;在 Linux 系统中,复制的快捷键是 Ctrl+Shift+C。了解这些快捷键可以提高用户的工作效率,方便地进行文本或文件复制操作。
