汇编语言

HuiPuKui / 2023-05-04 / 原文

汇编语言

debug 是 DOS、Windows 都提供的实模式(8086 方式)程序的调试工具。

  • R 命令查看、改变 CPU 寄存器的内容
  • D 命令查看内存中的内容
  • E 命令改写内存中的内容
  • U 命令将内存中的机器指令翻译成汇编指令
  • T 命令执行一条机器指令
  • A 命令以汇编指令的格式在内存中写入一条机器指令

寄存器

AH&AL = AX (accumulator):累加寄存器
BH&BL = BX (base):基址寄存器
CH&CL = CX (count):计数寄存器
DH&DL = DX (data):数据寄存器
SP (Stack Pointer):堆栈指针寄存器
BP (Base Pointer):基址指针寄存器
SI (Source Index):源变址寄存器
DI (Destination Index):目的变址寄存器
IP (Instruction Pointer):指令指针寄存器
CS (Code Segment):代码段寄存器
DS (Data Segment):数据段寄存器
SS (Stack Segment):堆栈段寄存器
ES (Extra Segment):附加段寄存器
OF overflow flag 溢出标志 操作数超出机器能表示的范围表示溢出,溢出时为 1
SF sign Flag 符号表示 记录运算结果的符号,结果负时为 1
ZF zero flag 零标志 运算结果等于 0 时为 1,否则为 0
CF carry flag 进位标志 最高有效位产生进位时为 1,否则为 0
AF auxiliary carry flag 辅助进位标志,运算时,第 3 位向第 4 位产生进位时为 1,否则为 0
PF parity flag 奇偶标志 运算结果操作数位为 1 的个数为偶数个数时为 1,否则为 0
DF direcion flag 方向标志 用于串处理 DF = 1 时,每次操作后使 SI 和 DI 减小,DF = 0 时则增大
IF interrupt flag 中断标志 IF = 1 时,允许 CPU 响应可屏蔽中断,否则关闭中断
TF trap flag 陷阱标志 用于调试单步操作

mov 指令

ah 高八位
al 低八位
mov 寄存器、数据          比如:mov ax,8
mov 寄存器、寄存器        比如:mov ax,bx
mov 寄存器、内存单元      比如:mov ax,[0]
mov 内存单元、寄存器      比如:mov [0],ax
mov 段寄存器、寄存器      比如:mov ds ax

add 指令

add ax,bx

sub 指令

sub ax,bx

mul 指令

  • 两个相乘的数:两个相乘的数,要么都是 8 位,要么都是 16 位。如果是 8 位,一个默认放在 AL 中,另一个放在 8 位 reg 或内存字节单元中:如果是 16 位,一个默认放在 AX 中,另一个放在 16 位 reg 或内存字单元中。
  • 结果:如果是 8 位乘法,结果默认放在 AX 中:如果是 16 位乘法,结果高位默认放在 DX 中存放,低位在 AX 中存放
计算 100 * 10
mov al,64
mov bl,A
mul bl

计算 100 * 10000
mov ax,64
mov bx,2710
mul bx

div 指令

  • 除数:有 8 位和 16 位两种,在一个 reg 或内存单元中
  • 被除数:默认放在 AX 或 DX 和 AX 中,如果除数为 8 位,被除数则为 16 位,默认在 AX 中存放:如果除数位16位,被除数则为 32 位,在 DX 和 AX 中存放,DX 存放高 16 位,AX 存放低 16 位
  • 结果:如果除数为 8 位,则 AL 存储则 AL 存储除法操作的商,AH 存储除法操作的余数:如果除数为 16 位,则 AX 存储除法操作的商,DX 存储除法操作的余数
div reg
div 内存单元

and 指令

mov al,63 (01100011B)
and al,3B (00111011B)
执行后 al = 23 (00100011B)

or 指令

mov al,63 (01100011B)
or al,3B (00111011B)
执行后 al = 7B (01111011B)

shl 和 shr 指令 (左移、右移)

mov al,48 (01001000B)
shl al,1
执行后 al = 90 (10010000B)

mov ax,F
shr ax,1
执行后 ax = 0007

rol、ror 循环左移、右移
rcl、rcr 带进位的循环左移、右移

inc 和 dec 指令(自增、自减)

inc ax
dec ax

nop(空指令)

nop

xchg 指令(交换)

xchg ax,bx

neg 指令(取补)

neg ax

int 中断