数据处理的两个基本问题
汇编语言中数据位置的表达
在汇编语言中如何表达数据的位置?
汇编语言中用三个概念来表达数据的位置:
1) 立即数(idata)
2) 寄存器
3) 内存(段地址SA和偏移地址EA)
寻址方式
当数据存放在内存中的时候,我们可以用多种方式来给定这个内存单元的偏移地址,这种定位内存单元的方法一般被称为寻址方式。
指令要处理的数据有多长?
8086CPU的指令,可以处理两种尺寸的数据,byte和word。
所以在机器指令中要指明指令进行的是字操作还是字节操作。
1) 通过寄存器名指明要处理的数据的尺寸。
2) 在没寄存器名存在的情况下,用操作符X ptr指明内存单元的长度,X在汇编指令中可以为word或byte。
3) 其他方法,有些指令默认了访问的是字单元还是字节单元,比如,push[1000H]就不用指明访问的是字单元还是字节单元,因为push指令只进行字操作。
寻址方式的综合应用
8086CPU提供的如[bx+si+idata]的寻址方式为结构化数据的处理提供了方便。
div指令
div是除法指令。
1) 除数:有8位和16位两种,在一个寄存器或内存单元中。
2) 被除数:默认放在AX或DX和AX中,如果除数为8位,被除数则为16位,默认在AX中存放;如果除数为16位,被除数则为32位,在DX和AX中存放,DX存放高16位,AX存放低16位。
3) 结果:如果除数为8位,则AL存储除法操作的商,AH存储除法操作的余数;如果除数为16位,同AX存储除法操作的商,DX存储除法操作的余数。
格式如下:
div reg
div 内存单元
div byte ptr ds:[0] ;除数指定为8位
(al) = (ax)/((ds)*16+0)的商;
(ah)=(ax)/((ds)*16+0)的余数。
div word ptr es:[0]
(ax) =( (dx)*10000H+(ax))/((ex)*16+0)的商;
(dx)= ( (dx)*10000H+(ax))/((ex)*16+0)的余数。
div byte ptr [bx+si+8]
(al)=(ax)/((ds)*16+(bx)+(si)+8)的商;
(ah)= (ax)/((ds)*16+(bx)+(si)+8)的余数。
div word ptr [bx+si+8]
(ax)=((dx)*10000H)+(ax))/((ds)*16+(bx)+(si)+8))的商;
(ax)=((dx)*10000H)+(ax))/((ds)*16+(bx)+(si)+8))的余数。
实践:100001/100
被除数100001大于65535(FFFF、十六位),不能用ax寄存器存放,所以我们只能用dx和ax两个寄存器联合存放100001,也就是说要进行16位的除法,除数100小于255,可以在一个8位寄存器中存放,但是,因为被除数是32位的,除数应为16位,所以要用一个16位寄存器来存放除数100。
100001表为十六进制:186A1H。
mov dx,1
mov ax,86A1H
mov bx,100
div bx
程序执行后,(ax)=03E8H(即1000),(dx)=1(余数为1)。
计算1001/100
被除数1001可用ax寄存器存放。除数100可用8位寄存器存放。即可进行8位的除法。
mov ax,1001
mov bl,100
div bl
程序执行后,(al)=0AH(即10),(ah)=1(余数为1)。
伪指令dd
db 定义字节型数据;define byte; 一个字节表示8个位;
dw 定义字型数据; define word; 一个节表示两个字节;
dd 定义双字型数据;define dword(double word,双字)。两个字。四个字节。
data segment
db 1
dw 1
dd 1
data ends
在data段中定义了三个数据:
第一个数据为01H,在data:0处,占1个字节;
第二个数据为0001H,在data:1处,占1个字,两个字节;
第三个数据为00000001H,在data:3处,点2个字,四个字节。
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个字节,它们是0、1、2、0、1、2、0、1、2,相当于db 0,1,2, 0,1,2, 0,1,2
db 3 dup (‘abc’, ‘ABC’)
定义了18个字节,它们是’ abcABC abcABC abcABC’,相当于 db ‘abcABC abcABC abcABC’
dup的使用格式如下:
db 重复的次数 dup (重复的字节型数据)。
dw 重复的次数 dup (重复的字型数据)。
dd 重复的次数 dup (重复的双字数据)。
dup是一个十分有用的操作符,比如我们要定义一个容量为200个字节的栈段。
stack segment
db 200 dup (0)
stack ends