《汇编语言》实验九

时间:2022-04-05 04:50:40

实验八 分析一个奇怪的程序

assume cs:codesg

codesg segment

mov ax,4c00h

int 21h

start: mov ax,0

s: nop
nop

mov di,offset s
mov si,offset s2
mov ax,cs:[si]
mov cs:[di],ax

s0: jmp short s

s1: mov ax,0
int 21h
mov ax,0

s2: jmp short s1
nop

codesg ends
end start

直接从程序的开头开始看:

mov di,offset s    
mov si,offset s2
mov ax,cs:[si]
mov cs:[di],ax

这个是把段s的地址放到di中,s2的地址放到si中。
然后把s2段中的内容读取到ax中。
之后把ax中的内容送入到s1段中。

注意:内存往寄存器中读取自动读取两个字节如果没特别说明,段没有专门的地址,其地址就是段中开头第一个数据的地址。而该段该指令仅占两个字节,故就可以实现段的复制。

之后跳到s段,而s段中的内容是跳到s1段,最后在s1段中结束程序,就是这个样子,很好理解。