1- div除法指令
(1) 除数: 有8位和16位两种,在一个寄存器或内存单元中.
(2) 被除数: 默认放在AX和DX或AX中
除数为8位, 被除数为16位, 默认在AX中存放.
除数为16位, 被除数为32位, 在DX或AX中存放. AX存放低16位,DX存放高16位.
(3) 结果
除数为8位, 则AL存储除法操作的商, AH存放余数
除数为16为, 则AX存储除法操作的商, DX存放余数
2- 格式如下
div reg
div 内存单元
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)的余数
div byte ptr [bx + si + 8]
含义为:(al) = (ax)/((ds)*16+(bx)+(si)+8)的商
(ah) = (ax)/((ds)*16+(bx)+(si)+8)的余数
编程:利用除法指令计算 100001/100 (16位除法)
分析:100001大于65535,所以只能用dx和ax两个寄存器联合存放100001,也就是要进行16位除法,除数100小于255,可以在一个8位寄存器中存放,但是因为被除数是32位的,除数必须是16位,所以用16位的寄存器来存放除数100.
因为要分别为dx和ax赋100001的高16位和低16位,所以应先将100001表示为16进制形式.186A1H.
100表示为16进制形式64H,用bx存储
(ax) = [(dx)*10000H+(ax)]/(bx)的商 03E8H
(dx) = [(dx)*10000H+(ax)]/(bx)的余数 0001H
编程:利用除法指令计算1001/100(8位的除法)
被除数可以用ax存放,除数可以用8位寄存器bl
(al)=0AH
(dx)=1H
3- 伪指令 dd
db 字节型数据
dw 字型数据
dd dword (double word)双字型数据
data segment
db 1 ;为01H 在data:0处, 占1个字节
dw 1 ;为0001H 在data:1处, 占1个字
dd 1 ;为00000001H 在data:3处, 占2个字
data ends
1 ;用div计算data段中第一个数据除以第二个数据后,商存放到第三个数据的存储单元中. 2 ;余数存储到第四个存储单元中. 3 assume cs:codesg,ds:datasg 4 datasg segment ;储存 0B60:0 F A1 86 01 00 64 00 00 00 00 00 5 dd 100001 6 dw 100 7 dw 0 8 dw 0 9 datasg ends 10 codesg segment 11 start: mov ax,datasg 12 mov ds,ax 13 mov ax,ds:[0] ;ax存储低16位 14 mov dx,ds:[2] ;dx存储高16位 15 div word ptr ds:[4] ;计算除法 16 mov ds:[6],ax ;商存储第3个单元 17 mov ds:[8],dx ;余数存储第4个单元 18 19 mov ax,4c00h 20 int 21h 21 codesg ends 22 end start
4- dup 用来进行数据重复的
db 3 dup (0) ;定义了3个字节,相当于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'
可见dup的使用格式如下:
db 重复的次数 dup(重复的字节型数据)
dw 重复的次数 dup(重复的字型数据)
dd 重复的次数 dup(重复的双字数据)
定义一个容量为200个字节的栈段
stack segment
dw 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0
dw 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0
dw 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0
dw 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0
dw 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0
stack ends
stack segment
dw 200 dup (0)
stack ends