总结:
寄存器 BX ,SI,DI,PB:
8086CPU的寄存器:AX,BX,CX,DX,AH,AL,BH,BL,CH,CL,DH,DL,SP,BP,SI,DI
段寄存器有:CS,SS,DS,ES
而,在8086CPU中只有4中寄存器可以用在[.....]中进行寻址。分别是:BX,BP,SI,DI 比如mov ax,[bx]是对的,而mov ax,[cx]就是错的。而要用灵活寻址的方式来进行组合的话,也是有规则的。只能是BX和BP中的一个和SI和DI中的一个进行组合。比如mov ax,[bx+si+常数]是对的,而mov ax,[bx+bp+常数]是错的。而还有一个规则就是只要在[...]中使用了寄存器BP,那么段地址就默认在段寄存器SS中。
寻址方式:
- 直接寻址:[地址]
- 寄存器间接寻址: [bx],[bp],[si],[di]
- 寄存器相对寻址: [bx+常数],[bp+常数],[si+常数],[di+常数]
- 基址变址寻址:[bx+si],[bx+di],[bp+si],[bp+di]
- 相对基址变址寻址:[bx+si+常数],[bx+di+常数],[bp+si+常数],[bp+di+常数]
指令处理数据长度:
一般用16位寄存器进行操作,那么CPU进行的就是16位数的操作,也就是字单元的操作。比如 mov ax,[0] 那么传入AX的会使一个字单元。
而用8位寄存器进行操作,那么CPU进行的就是8位数的操作,也就是字节单元的操作。比如 mov al,[0] 那么传入AX的将会是一个字节单元。
而当没有寄存器名时,我们可以指定是8位数操作还是16位数操作。
我们可以用操作符:word ptr 或 byte ptr 前者指定是字单元的操作,后者指定是字节单元的操作。
使用方法:
mov word ptr ds:[0],1
inc word ptr [bx]
mov byte ptr ds:[0],1
inc byte ptr [bx]
div指令:
div指令为汇编语言中的除法指令,用法:div word/byte ptr 内存单元或寄存器 。
规则:除数储存在内存单元或寄存器中,有8位和16位两种
被除数在寄存器AX或者AX和DX中。当除数为8位时,被除数就为16位,就储存在AX中,当除数为16位时,被除数就为32位,就储存在AX和DX中。当被除数为32位时,AX中存放低16位,DX中存放高16位。
商和余数:当除数为8位时,商和余数都储存在寄存器AX中,AH中存放余数,AL中存放商。
当除数为16位时,商储存在AX中,余数储存在DX中。
如果我们要计算100001除以100:因为100001大于65535,所以只用AX来存放是不够的,所以要用AX和DX同时来存放。而100小于255,用一个8位寄存器来存放时没有问题的,但是因为被除数是32位,所以得用一个16位寄存器来存放。
我们用debug来试试:
因为要用DX存放高16位,AX存放底16位,所以我们要先把100001化成16进制,为186A1H,我们把那个1放到DX中,剩下的86A1放入AX中。然后我们将除数100放入寄存器BX中。
然后我们把命令随便写入一段内存,然后设置一些基本数据。
执行
可以看到DX中存放的是余数1,AX中存放的是商1000
伪指令dd和dup:
db定义字节型数据,dw定义字型数据,dd定义双字型数据(就是占两个字,4个字节)
dup用来重复的:如 要定义两百个字节的栈,用dup就会显得很方便:db 200 dup (0) 相当于db 0,0,0,0......省略200个0.
具体使用方法:db/dw/dd 重复的次数 dup (要重复定义的各种类型的数据)
如: db 3 dup ('abc',def') 相当于 db 'abc','def','abc','def','abc','def'
后面的题目: