reg表示一个寄存器,sreg表示一个段寄存器
reg包括:ax、bx、cx、dx、ah、al、bh、bl、ch、cl、dh、dl、sp、bp、si、di
sreg包括:ds、ss、cs、es
bx、si、di和bp
在8086CPU中,只有4个寄存器可以用在[……]中来进行内存单元的寻址。
在[……]中,这4个寄存器可以单个出现,或以4种组合出现:bx和si、bx和di、bp和si、bp和di。
bx和bp、si和di不能放一起使用。si指向源数据地址,di指向目的数据地址。
只要在[……]中使用寄存器bp,而指令中没有显性地给出段地址,段地址就默认在ss中。
处理数据的地方
指令在执行前,所要处理的数据可以在3个地方:CPU内部、内存、端口。
数据位置的表达
立即数(idata)
对于直接包含在机器指令中的数据,在汇编语言中称为:立即数,在汇编指令中直接给出。
寄存器
指令要处理的数据在寄存器中,在汇编指令中给出相应的寄存器名。
段地址(SA)和偏移地址(EA)
指令要处理的数据在内存中,在汇编指令中可用[X]的格式给出EA,SA在某个段寄存器中。
存放段地址的寄存器可以是默认的。bx、si、di默认段地址存在第ds中。
bp默认段地址在ss中。
寻址方式
处理的数据长度
-
通过寄存器名指明要处理的数据的尺寸。
mov ax,1 mov bx,ds:[0] mov ds,ax ;通过寄存器指明了是字操作。 mov al,1 mov al,bl mov al,ds:[0] ;通过寄存器指明了是字节操作。
-
在没有寄存器名存在的情况下,用操作符X ptr指明内存单元的长度,X在汇编指令中可以为word或byte。
mov word ptr ds:[0],1 inc word ptr [bx] ;用word ptr指明了内存单元是一个字单元。 mov byte ptr ds:[0],1 inc byte ptr [bx] ;用byte ptr指明了内存单元是一个字节单元。
-
其他方法
有些指令默认了访问的是字单元还是字节单元。push指令只进行字操作。
寻址
8086CPU提供的[bx+si+idata]的寻址方式为结构化数据的处理提供了方便。 可以在编程的时候,用结构化的角度去看待所要处理的数据。
一般来说,可以用[bx+si+idata]的方式来方位结构体中的数据,用bx定位整个结构体,用idata定位结构体中的某一个数据项,用si定位数组项中的每个元素。
div指令
div是除法指令,用div做除法注意的问题
- 除数:有8位和16位两种,在一个reg或内存单元中。
- 被除数:默认放在AX或DA和AX中,如果除数为8位,被除数则为16位,默认在AX中存放。如果除数为16位,被除数则为32位,在DX和AX中存放,DX存放高16位,AX存放低16位。
- 结果:如果除数为8位,则AL存储除法操作的商,AH存储除法操作的余数;如果除数为16位,则AX存储除法操作的商,DX存储除法操作的余数。
div byte ptr ds:[0]
(al) = (ax)/((ds)*16+0)的商
(ah) = (ax)/((ds)*16+0)的余数
div word ptr es:[0]
(ax) = [(dx)* 10000H+(ax)]/((es)*16+0)的商
(dx) = [(dx)* 10000H+(ax)]/((es)*16+0)的余数
伪指令dd
dd是用来定义dword双字型数据。
dup
dup是一个操作符,同db、dw、dd等一样,也是由编译器识别处理的符号。和db、dw、dd等数据定义伪指令配合使用。
db 3 dup (0)
定义了3个字节,值都是0。相当于db 0,0,0
db 3 dup (0,1,2)
定义了9个字节,相当于db 0,1,2,0,1,2,0,1,2
db 3 dup ('abc','ABC')
定义了18个字节,相当于db ‘abcABCabcABCabcABC’
db 重复的次数 dup (重复的字节型数据)
dw 重复的次数 dup (重复的字型数据)
dd 重复的次数 dup (重复的双字型数据)
定义了18个字节,相当于db ‘abcABCabcABCabcABC’
db 重复的次数 dup (重复的字节型数据)
dw 重复的次数 dup (重复的字型数据)
dd 重复的次数 dup (重复的双字型数据)