实验八 分析一个奇怪的程序
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段中结束程序,就是这个样子,很好理解。