汇编语言3
8086CPU的指令,可以处理两种尺寸的数据,byte和word。所以在机器指令中要指明,指令进行的是字操作还是字节操作。对于这个问题,汇编语言中用一下方法处理。
(1)通过寄存器名指明要处理的数据的尺寸。
例如:
下面的指令中,寄存器指明了指令进行的是字操作:
mov ax,1
mov bx,ds:[0]
mov ds,ax
mov ds:[0],ax
inc ax
add ax,1000
下面的指令中,寄存器指明了指令进行的是字节操作:
mov al,1
mov al,bl
mov al,ds:[0]
mov ds:[0],al
inc al
add al,100
(2)在没有寄存器名存在的情况下,用操作符 X ptr 指明内存单元的长度,X在汇编指令中可以为word或byte。
例如:
下面的指令中,用word ptr 指明了指令访问的内存单元是一个字单元:
mov word ptr ds:[0],1
inc word ptr [bx]
inc word ptr ds:[0]
add word ptr [bx],2
下面的指令中,用byte ptr 指明了指令访问的内存单元是一个字单元:
mov byte ptr ds:[0],1
inc byte ptr [bx]
inc byte ptr ds:[0]
add byte ptr [bx],2
在没有寄存器参与的内存单元访问指令中,用word prt 或byte ptr 显性地指明所要访问的内存单元的长度是很必要的。否则,CPU无法得知所要访问的单元,还是字节单元。
假如我们用Debug查看内存的结果如下:
2000:1000 FF FF FF FF FF FF ......
那么指令:
mov ax,2000H
mov ds,ax
mov byte ptr [1000H],1
将使内存中的内容变为:
2000: 1000 01 FF FF FF FF FF ......
而指令:
mov ax,2000H
mov ds,ax
mov word ptr [1000H],1
将使内存中的内容变为:
2000:1000 01 00 FF FF FF FF ......
这是因为 mov byte ptr [1000H],1访问的是地址为 ds:1000H 的字节单元,修改的是ds:1000H 单元的内容;而mov word ptr [1000H],1 访问的是地址为 ds:1000H 的字单元,修改的是 ds:1000H 和 ds:1001H 两个单元的内容。
PTR用来指出操作数的类型或尺寸,通常用在跳转/调子程序或寻址。寻址时用来指明是BYTE、WORD还是DWORD,跳转时则是FAR或NEAR。
(3) 其他方法
有些指令默认了访问的是字单元还是字节单元,比如:push [1000H] 就不用指明访问的是字单元还是字节单元,因为push指令只进行字操作。
分析一下指令执行过程:
(1): mov ax,6622h
(2): jmp 1000:3
(3):mov ax,0000
(4):mov bx,ax
(5):jmp bx
(6):mov ax,0123h
(7):怎么执行?
//初始: CS:IP为2000:0, 2000:0的内存 00 00 00 00 00 00 00 00 00 00 00 00 00
(1): mov ax,6622h //执行后:CS:IP为2000:3 2000:0的内存 B8 22 66 00 00 00 00 00 00 00 00 00 00
(2): jmp 1000:3 //载入后:CS:IP为2000:8 2000:0的内存 B8 22 66 EA 03 00 00 10 00 00 00 00 00
//执行后:CS:IP为1000:3
//初始: 1000:0的内存 00 00 00 00 00 00 00 00 00 00 00 00 00
(3):mov ax,0000 //执行后:CS:IP为1000:6 2000:0的内存 00 00 00 B8 00 00 00 00 00 00 00 00 00
(4):mov bx,ax //执行后:CS:IP为1000:8 2000:0的内存 00 00 00 B8 00 00 8B D8 00 00 00 00 00
(5):jmp bx //载入后:CS:IP为1000:10 2000:0的内存 00 00 00 B8 00 00 8B D8 FF E3 00 00 00
//执行后CS:IP为1000:0
(6):mov ax,0123h //执行后:CS:IP为1000:3 2000:0的内存 B8 23 31 B8 00 00 00 00 00 00 00 00 00
(7):怎么执行? //(6)执行后 会到(3)出执行,这是一个死循环
1.汇编语言源程序中有两种指令,一种 汇编指令,一种伪指令。
2.汇编指令有对应的机器指令,最终为CPU所执行
3.伪指令没有对应的机器指令,由编译器执行的
4.assume,segment,ends,end均伪指令
第一步:编写汇编源代码
新建文本 1.txt
代码如下:
assume cs:codesg ;将cs寄存器和codesg代码段关联
codesg segment ;codesg代码段开始
mov ax,0123H
mov bx,0456H
add ax,bx
add ax,ax
mov ax,4c00H
int 21 ;mov ax,4c00 int 21 这2条指令实现程序返回
codesg ends ;codesg代码段结束 segment,ends成对使用
end ;整个汇编程序结束
第二步:对源代码进行编译连接
下载 masm5 编译工具, 放在c盘根目录
第三步:得到最终 exe