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