汇编语言:x86汇编指令大全及其注意事项
Part 1:instruction
积少成多,持续更新。(这将会是一个极其漫长的过程)
表格中各条指令的顺序根据笔者所认为的重要或常用程度进行排序,仅供参考。
Part 2
本表格中所涉及的F是指状态寄存器,CF指进位标志位,其它以此类推。
2.1 (逻辑)运算、移位等常用指令
这一部分记录汇编语言程序设计当中使用频率最高的一部分指令。
2.1 (逻辑)运算、移位等常用指令
这一部分记录汇编语言程序设计当中使用频率最高的一部分指令。
指令 | 作用 | 注意事项 | 示例 |
---|---|---|---|
mov dest, src | 传送指令 | 1.dest和src不能同时为存储器操作数 2.CS不能作为dest 3.段寄存器之间不能互相传送 4.立即数不能送入段寄存器 |
mov ax,word ptr[bx+si+2] |
add dest,src | 加法指令 | dest,src不能同时为存储器操作数或段寄存器 |
add ax,cx |
adc dest,src | 带进位加法指令 | dest=dest+src+CF,常用于多字节加法 | |
inc dest | 加一指令 | 1.此操作不影响CF的状态 | inc byte ptr[si] |
sub dest,src | 减法指令 | 1.dest,src的要求与add相同 2.触发OF:异号相减且结果的符号为与被减数不同 |
sub ax,cx |
sbb dest,src | 带进位减法 | 常用于多字节减法 | |
dec dest | 减一指令 | 不影响CF的状态,但其他几个标志位都会受到影响 | dec ax |
mul dest | 无符号乘法指 | 1.dest为字节数据,则与AL相乘,结果放入AX 2.dest为字数据,与AX相乘结果低16位放入AX,高16位放入DX 3.dest不能是立即数 |
mul ax |
imul dest | 有符号乘法 | 细节与mul完全相同,对最高位的解释不同 | imul ax |
div dest | 无符号除法 | 1.dest为字节数据,用AX除以dest,商放在AL,余数放在AH 2.dest为字数据,用低16位为AX,高16位为DX的双字数据除以dest,商放在AX,余数放在DX |
|
idiv dest | 带符号除法 | 与无符号完全相同。除法溢出时结果无效 | idiv ax |
cbw | 扩展AL为AX字数据 | 1.仅用于扩展带符号数,无符号直接清零即可 2.不带操作数 |
cbw |
cwd | 扩展AX字为DX,AX双字数据 | 要求与cbw相同 | cwd |
seg | 取标号或变量的段地址 | mov di,seg label | |
lea | 取偏移地址 | 1.与offset作用类似 2.load efficient address的简写 |
lea ax,label |
offset | 取偏移地址 | 1.作用与lea相同 2.速度比lea快 |
mov ax,offset label |
org | 设定程序段起始地址(偏移) | 1.是origin的缩写 2.若无org默认程序从cs:0开始存放指令代码 3.两个org指令之间空余的空间用0填充 |
org offsetVal |
xlat | 转换表指令 | 1.BX存放表的首地址,AL存放当前表中元素的偏移量 2.不影响F的状态 |
xlat ;无需操作数 |
2.2 循环移位指令
循环移位指令非常容易混淆,但是却十分重要,因此需要牢牢记住并时常查阅此表。
指令 | 作用 | 注意事项 | 示例 |
---|---|---|---|
SHL | 逻辑左移指令 | 1.最高位进入CF中 2.最低位直接用0填充 |
SHL AH,1 |
SHR | 逻辑右移指令 | 1.最低位进入CF中 2.最高位直接用0填充 |
SHR BX,1 |
SAL | 算术左移指令 | 行为与SHL没有差别 | SAL BL,CL |
SAR | 算术右移指令 | 1.最低位进入到CF中 2.最高位右移后填充最高位(即用最高位填充最高位) |
SAR CL,BX |
ROL | 循环左移指令 | 最高位进入到CF中并填充最低位 | 同上 |
ROR | 循环右移指令 | 最低位进入到CF中并填充最高位 | 同上 |
RCL | 带进位循环左移指令 | 1.最低位由CF填充 2.最高位进入CF |
同上 |
RCR | 带进位循环右移指令 | 1.最高位由CF填充 2.最低位进入CF |
同上 |
2.3 数据串操作指令
重复前缀指令与数据串操作指令连用常常能起到事半功倍的效果,注意使用了大大提升汇编程序的简洁性。
指令 | 作用 | 注意事项 | 示例 |
---|---|---|---|
lods/lodsw/lodsb | 载入数据串指令 | 1.具体操作:从ds:si读取一个字节/字/双字到AL,AX,EAX中,SI根据DF的值进行增减对应的数值 | lodsw ;无需操作数 |
stos/stosw/stosb | 存数据串指令 | 1.AX/AL的内容存放到ES:DI中 2.指针修改是自动且隐式的 |
stos/stosw/stosb ;无需操作数 |
cmps/cmpsb/cmpsw | 数据串比较指令 | cmps需要两个操作数(数据串首地址),后两个无需操作数,字符串的比较由DI和SI完成 | ;NULL |
movs/movsb/movsw | 数据串传送指令 | 注意事项参照上方的cmps等的用法 | ;NULL |
rep/repz/repnz | 重复前缀指令 | 1.当cx的内容不为0时执行操作(先判断) 2.用CLD,STD控制增、减量修改 3.与数据串操作指令结合使用,实现内存拷贝、比较等功能 |
不需要操作数 |
2.4 逻辑运算指令
这一部分指令是以我的理解进行划分,所以可能不太精准,有意见欢迎在评论区提出。
指令 | 作用 | 注意事项 | 示例 |
---|---|---|---|
cmp dest,src | 1.比较指令 | 1.用dest减去src,但不保存结果 2.相减的结果影响F |
cmp ax,cx |
test dest,src | 1.将dest与src相与 | 可用来测试是否为零等,结果不保存 2.影响F |
test ax,ax |
neg dest | 取补指令,得到相反数 | 影响F | neg ax |
not dest | 取反指令 | 1.将操作数每一位按位取反 2.不影响F |
not AX |
2.5 基于大小关系的跳转指令
在使用了cmp,sub,subb等指令后通常使用如下这些指令衔接以便进行下一步的操作,令程序十分简洁。需要注意的是,根据有符号和无符号数需要选择不同的指令进行基于大小关系的跳转。
无符号数 | |
---|---|
指令 | 作用 |
JA label | 大于时跳转 |
JAE label | 大于等于时跳转 |
JB label | 小于时跳转 |
JBE label | 小于等于时跳转 |
带符号数 | |
---|---|
指令 | 作用 |
JG label | 大于时跳转 |
JGE label | 大于等于时跳转 |
JL label | 小于时跳转 |
JEL label | 小于等于时跳转 |
无符号、带符号通用 | |
---|---|
JE label | 等于时跳转 |
JNE label | 不等于时跳转 |
2.6 基于单标志位的转移指令
根据标志寄存器F中标志位的状态决定是否进行跳转,通常在进行运算后结合这些指令进行跳转。
指令 | 作用 |
---|---|
JC label | CF=1时跳转 |
JNC label | CF=0时跳转 |
JZ label | ZF=1时跳转 |
JNZ label | ZF=0时跳转 |
JO label | OF=1时跳转 |
JNO label | OF=0时跳转 |
JS label | SF=1时跳转 |
JNS label | SF=0时跳转 |
JP label | SF=1时跳转 |
JNP label | PF=0时跳转 |
Part 3:Loading… …
第一次更新:2020-05-15 15:29
第二次更新:2020-05-22 00:14
第三次更新:2020-05-24 00:24
第四次更新:2020-05-24 21:10
持续更新中… …
到此这篇关于汇编语言:x86汇编指令大全及其注意事项的文章就介绍到这了,更多相关x86汇编指令大全内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
最新评论