8086汇编-实验8-jmp指令的理解
offset 標(biāo)號(hào):取標(biāo)號(hào)處的地址
mov 16位 offset 標(biāo)號(hào):取標(biāo)號(hào)偏移地址
mov 32位 offset 標(biāo)號(hào):取標(biāo)號(hào)段地址:偏移地址
程序入口:start
第一步:
地址:0005
指令:mov ax,0
結(jié)果:ax=0
第二步:
s
地址:0008
指令:nop
結(jié)果:分配1字節(jié)空間
第三步:nop
地址:0009
指令:nop
結(jié)果:分配1字節(jié)空間
第四步:
地址:000A
指令:mov di,offset s
結(jié)果:di=0008
第五步:
地址:000D
指令:mov si,offset s2
結(jié)果:si=0020,s2的偏移地址為0020
分析
s2:
jmp short s1 ;機(jī)器碼為EBF6
EB:短轉(zhuǎn)移機(jī)器碼
F6:s2+0002-s1
加2的原因是抵消掉ip自加的2
第六步:
地址:0010
指令:mov ax,cs:[si]
結(jié)果:ax=EBF6
第七步:
地址:0013
指令:mov cs:[di],ax
結(jié)果:0008=EB,0009=F6(填補(bǔ)第二步第三步nop處)
EBF6機(jī)器碼:ip指針-10(F6的補(bǔ)碼)
第八步:
地址:0016
指令:jmp short s
結(jié)果:ip=8,跳轉(zhuǎn)到0008
第九步:
地址:0008
指令:EBF6
結(jié)果:ip指針-10,ip=0008+0002-0010=0000
加2的原因:執(zhí)行EBF6之后ip指針自加2
第十步:
地址:0000
指令:
mov ax,4c00h
int 21h
結(jié)果:結(jié)束程序
總結(jié)
以上是生活随笔為你收集整理的8086汇编-实验8-jmp指令的理解的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 概率论-3.5 条件分布与条件期望
- 下一篇: 8086汇编-实验9-字符打印