总算进入正轨了
mov指令
- 这个命令应该是英文move的缩写吧。
所以大家也能猜出来。这个是赋值命令。
上代码
mov ax,11H ;这就是赋值给ax寄存器一个十六进制的11.
mov bx, ax ;把ax的数据赋值给bx
mov ax, 0x1122H ;也可以赋值地址,这个一般用于给寄存器。
mov ax, ds[0] ;也可以去寄存器数据赋值
add指令
- 用过高级语言的都应该晓得了。这是一个相加命令。
mov ax, 11H ;赋值11给ax
mov ds, ax ;指定ds地址到11H的位置
mov [0], 11H ;赋值个ds第一个段。也可以用ds:[0]方式赋值
mov dx, 22H ;赋值给段寄存器
add dx, [0] ;把ds[0]的数据加上dx的数据赋值给dx ;11 + 22 = 33
jum指令
- 英语为jump。翻译过来就是跳。它就是用来跳的。
- jum指令就是修改cs的段地址和偏移地址
可以用来修改指令运行位置。
就好比咱们高级语言判断。不只是这个。
它可以随意执行某处cs代码。
jmp 1000H:0
mov dx,11H ;赋值
mov ax,dx ;赋值
jmp 1 ;跳转cs的代码的第二行位置。这样就会一直出现循环执行
- cs不能直接通过mov修改地址。所以jmp就是用来修改代码执行位置的
loop指令
- 这是一个循环指令使用起来也非常简单
- 使用loop指令需要cx段寄存器用来储存循环数。每次循环之后
它会自动把cx的数减。
assume cs:code
code segment
mov ax,11H
mov dx,11H
mov cx,3 ;赋值cx为3
s: add ax,dx ;添加一个循环体标签为s
loop s ;执行循环体直到cx数值为0
;退出命令
mov ah,4ch
int 21h
code ends
end
注意事项:
使用loop时给cx为0时执行循环它也会减1这样就会得到段的最大值
就是FF会进入一个很长的循环。8086汇编没有高级语言那种防溢出。而且不会出现负数。出现负数会走到最大数。
call 和 ret
看到call应该就想到呼叫。不错。它就是用来调用函数的
它的流程是这样的
- 出现call命令首先会把下一条指令的偏移地址入栈。
然后跳转到call 命令后台的地址执行代码。 - 函数内部需要ret命令pop栈顶地址给ip。最后继续执行代码。
代码:
assume cs: code
code segment
call test //执行test函数
mov cx, 3344h
mov ah, 4ch
int 21h
test:
mov bx, 2211h
ret //把栈顶的地址pop出来给ip
code ends
end