鱼C论坛

 找回密码
 立即注册
查看: 3805|回复: 3

[学习笔记] 实验八

[复制链接]
发表于 2017-9-17 18:29:09 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
实验八

代码:
assume cs: code 

code 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 
                
code ends 
end start 

为什么能让程序结束呢?
起初我怎么想也不明白,听了小甲鱼老师的指点,我就明白了,在这里非常的感谢小甲鱼老师。

当s2的代码被复制到s处执行时,因为转移的距离是位移,就是所谓的标号处的地址 - jmp指令后一个字节的地址,用debug可以得到:
(A43FJXE$T{PLMT[96U1A~H.png

可以看出s1处的地址为18,s处的地址为8,相减得到10,因为他原本是在s2处的,所以应该是-10,所以向前转移10单元,所以程序会正常结束
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-12-7 16:01:22 | 显示全部楼层
复制过去的是机器码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-2-23 23:43:32 | 显示全部楼层
看看
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-2-24 22:53:24 | 显示全部楼层
kankan
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-25 01:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表