16位汇编指令_汇编语言指令表

16位汇编指令_汇编语言指令表汇编语言特点:与机器相关,执行效率高,调试复杂汇编语言优缺点:汇编语言和高级语言混合编写,互补数据表示类型:二进制B,八进制Q,十进制D,十六进制HBCD编码:用二进制来表示十进制数CPU资源和存储器:通用寄存器,标志寄存器,指令寄存器EAX,累加ECX,循环计数EDX,数据寄存器EBX,基址寄存器ESP,栈顶EBP,栈底ESI,扩展源指针EDI,扩

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

汇编语言特点:与机器相关,执行效率高,调试复杂

汇编语言优缺点:汇编语言和高级语言混合编写,互补

数据表示类型:二进制B,八进制Q,十进制D,十六进制H

BCD编码:用二进制来表示十进制数

CPU资源和存储器:通用寄存器,标志寄存器,指令寄存器

EAX,累加

ECX,循环计数

EDX,数据寄存器

EBX,基址寄存器

ESP,栈顶

EBP,栈底

ESI,扩展源指针

EDI,扩展目的指针

EIP,指令指针

SI(16位),变址寄存器,常用于存储器寻址时提供地址,源操作数指针

DI(16位),变址寄存器,常用于存储器寻址时提供地址,目的操作数指针

Flag寄存器

15

14

13

12

11

10

9

8

7

6

5

4

3

2

1

0

 

 

 

 

OF

DF

IF

TF

SF

ZF

 

AF

 

PF

 

CF

 

 

 

 

溢出

方向

中断

陷阱

符号

 

辅助

 

奇偶

 

进位

Debug状态

真假

OV/NV

DN/UP

EI/DI

 

NG/PL

ZR/NZ

 

AC/NA

 

PE/PO

 

CY/NC

进位CF,CF=1,运算结果表示有进位或者借位

零标志ZF,ZF=1,表示结果为0

符号标志SF,SF=1,运算结果最高位为1

奇偶标志PF,PF=1,运算结果最低8位1的个数为0或者偶数(奇)

溢出标志OF,OF=1,算数运算结果有溢出

辅助进位AF,AF=1,运算时有进位或借位

方向标志DF,DF=1,地址自动减少,用于串操作,控制地址变化方向

中断标志IF,IF=1,允许中断,用于控制外部可屏蔽中断是否可处理

陷阱标志TF,TF=1,处理器处于单步执行指令(处理器每执行一条指令便产生一个内部中断,可以对程序进行单步调试)

16位汇编物理地址与逻辑地址转换:逻辑地址<< 4位 + 偏移 = 物理地址(可以有多个逻辑地址)

CS(代码段),表示代码段的起始地址

SS(堆栈段),表示堆栈段的起始地址

DS(数据段),表示数据段的起始地址

ES(附加段),表示附加段的起始地址,附加段是数据段,用于数据保存,串操作指令将附加段作为其目的操作数的存放区域

段前缀CS:  ;使用代码段

段前缀SS:  ;使用栈段

段前缀DS:  ;使用数据段

段前缀ES:  ;使用附加段

默认访问DS,使用BP则访问主存(SS)

1M最多可分64K个段,最少能分16个段

8086有8个8位通用寄存器(al,ah…),8个16位通用寄存器(ax,bx…),6个状态标志(CF,ZF,SF,PF,OF,AF)和3个控制标志(DF,IF,TF),4个段寄存器,4种逻辑段,4个段前缀指令

 

立即数寻址,mov ah,0x01

寄存器寻址,mov ah,[bh]

直接寻址,mov AX,ES:[2000H]

寄存器间接寻址,mov AX,[SI]

寄存器相对寻址,mov AX,[DI+05]

基址变址寻址,mov AX,[BX(BP)+SI]

相对基址变址寻址,mov AX,[BX+SI+05]

 

段内转移也称近转移(near ptr)

段内转移也称短转移(short)

段间转移也称远转移(far ptr)

 

8086汇编指令

[ASM]8088汇编指令

一、数据传输指令

───────────────────────────────────────

  它们在存贮器和寄存器、寄存器和输入输出端口之间传送数据.

  1. 通用数据传送指令.

    MOV 传送字或字节.

    MOVSX 先符号扩展,再传送.

    MOVZX 先零扩展,再传送.

    PUSH  把字压入堆栈.

    POP  把字弹出堆栈.

    PUSHA 把AX,CX,DX,BX,SP,BP,SI,DI依次压入堆栈.

    POPA  把DI,SI,BP,SP,BX,DX,CX,AX依次弹出堆栈.

    PUSHAD 把EAX,ECX,EDX,EBX,ESP,EBP,ESI,EDI依次压入堆栈.

    POPAD 把EDI,ESI,EBP,ESP,EBX,EDX,ECX,EAX依次弹出堆栈.

    BSWAP 交换32位寄存器里字节的顺序

    XCHG  交换字或字节.( 至少有一个操作数为寄存器,段寄存器不可作为操作数)

    CMPXCHG 比较并交换操作数.( 第二个操作数必须为累加器AL/AX/EAX )

    XADD  先交换再累加.( 结果在第一个操作数里 )

    XLAT  字节查表转换.

        ── BX 指向一张 256 字节的表的起点, AL 为表的索引值 (0-255,即

        0-FFH); 返回 AL 为查表结果. ( [BX+AL]->AL )

 

  2. 输入输出端口传送指令.

    IN   I/O端口输入. ( 语法: IN 累加器, )

    OUT   I/O端口输出. ( 语法: OUT ,累加器 )

    输入输出端口由立即方式指定时, 其范围是 0-255; 由寄存器 DX 指定时, 其范围是 0-65535.

    

  3. 目的地址传送指令.

    LEA  装入有效地址.

    例: LEA DX,string ;把偏移地址存到DX.

    

    LDS  传送目标指针,把指针内容装入DS.

    例: LDS SI,string ;把段地址:偏移地址存到DS:SI.

    

    LES  传送目标指针,把指针内容装入ES.

    例: LES DI,string ;把段地址:偏移地址存到ES:DI.

    

    LFS  传送目标指针,把指针内容装入FS.

    例: LFS DI,string ;把段地址:偏移地址存到FS:DI.

    

    LGS  传送目标指针,把指针内容装入GS.

    例: LGS DI,string ;把段地址:偏移地址存到GS:DI.

    

    LSS  传送目标指针,把指针内容装入SS.

    例: LSS DI,string ;把段地址:偏移地址存到SS:DI.

    

  4. 标志传送指令.

    LAHF  标志寄存器传送,把标志装入AH.

    SAHF  标志寄存器传送,把AH内容装入标志寄存器.

    PUSHF 标志入栈.

    POPF  标志出栈.

    PUSHD  32位标志入栈.

    POPD  32位标志出栈.

 

二、算术运算指令

───────────────────────────────────────

    ADD  加法.

    ADC  带进位加法.

    INC  加 1.

    AAA  加法的ASCII码调整.

    DAA  加法的十进制调整.

    SUB  减法.

    SBB  带借位减法.

    DEC  减 1.

    NEC  求反(以 0 减之).

    CMP  比较.(两操作数作减法,仅修改标志位,不回送结果).

    AAS  减法的ASCII码调整.

    DAS  减法的十进制调整.

    MUL  无符号乘法.

    IMUL  整数乘法.

    以上两条,结果回送AH和AL(字节运算),或DX和AX(字运算).

    

    AAM  乘法的ASCII码调整.

    DIV  无符号除法.

    IDIV  整数除法.

    以上两条,结果回送:

    商回送AL,余数回送AH, (字节运算); 或商回送AX,余数回送DX, (字运算).

    

    AAD  除法的ASCII码调整.

    CBW  字节转换为字. (把AL中字节的符号扩展到AH中去)

    CWD  字转换为双字. (把AX中的字的符号扩展到DX中去)

    CWDE  字转换为双字. (把AX中的字符号扩展到EAX中去)

    CDQ  双字扩展.   (把EAX中的字的符号扩展到EDX中去)

 

三、逻辑运算指令

───────────────────────────────────────

    AND  与运算.

    OR  或运算.

    XOR  异或运算.

    NOT  取反.

    TEST 测试.(两操作数作与运算,仅修改标志位,不回送结果).

    SHL  逻辑左移.

    SAL  算术左移.(=SHL)

    SHR  逻辑右移.

    SAR  算术右移.(=SHR)

    ROL  循环左移.

    ROR  循环右移.

    RCL  通过进位的循环左移.

    RCR  通过进位的循环右移.

    以上八种移位指令,其移位次数可达255次.

    移位一次时, 可直接用操作码. 如 SHL AX,1.

    移位>1次时, 则由寄存器CL给出移位次数.

    如   MOV CL,04

        SHL AX,CL

 

四、串指令

───────────────────────────────────────

    DS:SI 源串段寄存器 :源串变址.

    ES:DI 目标串段寄存器:目标串变址.

    CX   重复次数计数器.

    

    AL/AX 扫描值.

    D标志  0表示重复操作中SI和DI应自动增量; 1表示应自动减量.

    Z标志 用来控制扫描或比较操作的结束.

    

    MOVS  串传送.

    ( MOVSB 传送字符. MOVSW 传送字. MOVSD 传送双字. )

    

    CMPS  串比较.

    ( CMPSB 比较字符. CMPSW 比较字. )

    

    SCAS  串扫描.

    把AL或AX的内容与目标串作比较,比较结果反映在标志位.

    

    LODS  装入串.

    把源串中的元素(字或字节)逐一装入AL或AX中.

    ( LODSB 传送字符.  LODSW 传送字.  LODSD 传送双字. )

    

    STOS  保存串.

    是LODS的逆过程.

    

    REP      当CX/ECX<>0时重复.

    REPE/REPZ   当ZF=1或比较结果相等,且CX/ECX<>0时重复.

    REPNE/REPNZ  当ZF=0或比较结果不相等,且CX/ECX<>0时重复.

    REPC      当CF=1且CX/ECX<>0时重复.

    REPNC     当CF=0且CX/ECX<>0时重复.

 

五、程序转移指令

───────────────────────────────────────

   1>无条件转移指令 (长转移)

    JMP      无条件转移指令

    CALL      过程调用

    RET/RETF    过程返回.

    

   2>条件转移指令 (短转移,-128到+127的距离内)

    ( 当且仅当(SF XOR OF)=1时,OP1  

    JA/JNBE    不小于或不等于时转移.

    JAE/JNB    大于或等于转移.

    JB/JNAE    小于转移.

    JBE/JNA    小于或等于转移.

    以上四条,测试无符号整数运算的结果(标志C和Z).

    

    JG/JNLE 大于转移.

    JGE/JNL 大于或等于转移.

    JL/JNGE 小于转移.

    JLE/JNG 小于或等于转移.

    以上四条,测试带符号整数运算的结果(标志S,O和Z).

    

    JE/JZ     等于转移.

    JNE/JNZ    不等于时转移.

    JC       有进位时转移.

    JNC      无进位时转移.

    JNO      不溢出时转移.

    JNP/JPO    奇偶性为奇数时转移.

    JNS      符号位为 “0” 时转移.

    JO       溢出转移.

    JP/JPE     奇偶性为偶数时转移.

    JS       符号位为 “1” 时转移.

    

  3>循环控制指令(短转移)

    LOOP      CX不为零时循环.

    LOOPE/LOOPZ   CX不为零且标志Z=1时循环.

    LOOPNE/LOOPNZ  CX不为零且标志Z=0时循环.

    JCXZ      CX为零时转移.

    JECXZ      ECX为零时转移.

    

  4>中断指令

    INT      中断指令

    INTO      溢出中断

    IRET      中断返回

    

  5>处理器控制指令

    HLT      处理器暂停, 直到出现中断或复位信号才继续.

    WAIT      当芯片引线TEST为高电平时使CPU进入等待状态.

    ESC      转换到外处理器.

    LOCK      封锁总线.

    NOP      空操作.

    STC      置进位标志位.

    CLC      清进位标志位.

    CMC      进位标志取反.

    STD      置方向标志位.

    CLD      清方向标志位.

    STI      置中断允许位.

    CLI      清中断允许位.

 

六、伪指令

───────────────────────────────────────

    DW       定义字(2字节).

    PROC      定义过程.

    ENDP      过程结束.

    SEGMENT    定义段.

    ASSUME     建立段寄存器寻址.

    ENDS      段结束.

    END      程序结束. 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/179492.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Mongo散记–聚合(aggregation)&amp; 查询(Query)

    Mongo散记–聚合(aggregation)&amp; 查询(Query)

    2021年12月3日
    34
  • SM8S33、TVS瞬态抑制二极管在汽车上的问题与应用

    SM8S33、TVS瞬态抑制二极管在汽车上的问题与应用随着经济的发展,现代汽车工业也在的高速发展,汽车的电子化、数字化、自动化、通讯化、自动驾驶等相关模块的成为汽车行主流方向;于此同时系统之间的EMC电磁兼容就显得尤为重要,我们专门为电气化的设计提供了高效的保护方案与应用!汽车电源系统的应用:1.首先了解一下基本情况:虽然高浪涌电压是汽车电路保护系统的应对对象,但是也要注意钳位的电压高度。电源系统,12V与24V的电池在指定的环境下最大输出电压的值。常见的稳压器和DC-DC转换器IC的最大输入电压的值。EMC电磁问题的解决,汽车电子系统是干扰源复杂

    2022年9月23日
    4
  • 怎么用python画圆的公式_运用python 画圆[通俗易懂]

    importnumpyasnpimportmatplotlib.pyplotaspltfrommatplotlib.patchesimportPolygonimportmatplotlib.patchesasmpatchesfig=plt.figure(figsize=(16,8))ax=fig.gca()ax.set_xlim(-5,18)ax.set_yl…

    2022年4月14日
    42
  • java查看环境变量的命令_java环境变量配置好了

    java查看环境变量的命令_java环境变量配置好了Linux是一个多用户的操作系统。每个用户登录系统后,都会有一个专用的运行环境。通常每个用户默认的环境都是相同的,这个默认环境实际上就是一组环境变量的定义。在Windows下,查看环境变量的命令是:set,这个命令会输出系统当前的环境变量。Linux下Linux查看环境变量准确的说是REDHAT下应该如何查看呢,命令是:export如果你想查看某一个名称的环境变量,命令是:echo$环境变量名,…

    2022年10月1日
    1
  • 多年收集的一些稀有软件_魔兽世界野外稀有小宠物

    多年收集的一些稀有软件_魔兽世界野外稀有小宠物QQ:365543212DigitalCanalMultipleLoadFootingv4.51CD(定义出梯形的、带状的或矩形的脚柱的多种负重)DigitalCanalQuickWallv5.71CD(保留墙设计软件,同时拥有卓越的精确性)DigitalCanalSpreadFootingv2.31CD(圆柱体设计软件,可以同时处理10个圆柱体还可以…

    2022年8月24日
    10
  • 操作系统主存储器空间的分配和回收_内存管理的功能

    操作系统主存储器空间的分配和回收_内存管理的功能1.什么是内存?有何作用?几个常用的数量单位2.进程运行的基本原理1.指令的工作原理2.逻辑地址vs物理地址3.从写程序到程序运行4.装入的三种方式1.绝对装入2.可重定位装入(静态重定位)3.动态运行时装入(动态重定位)5.链接的三种方式1.静态链接2.装入时动态链接3.运行时动态链接二、内存管理的概念1.内存空间的分配与回收1.单一连续分配2.固定分区分配3.动态分区分配1.首次适应算法2.最佳适应算法3.最坏适应算法

    2022年10月7日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号