鱼C论坛

 找回密码
 立即注册
查看: 2792|回复: 2

[技术交流] 实验8分析

[复制链接]
发表于 2022-3-17 00:34:33 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 18510682557 于 2022-3-17 00:41 编辑
assume cs:codesg
codesg segment

                mov ax, 4c00H           (3字节指令)
                int 21H                 (2字节指令)
        
start:         mov ax, 0                 (3字节指令)  
           s:  nop                       (2字节指令) (EBF6)执行jump前,IP会先指向下一条指令,这时在执行EBF6向上跳10个字节的位置,正好是 mov ax, 4c00 也就是0000的位置  第三步
       cs:ip ->nop                           
                
                mov di, offset s
                mov si, offset s2
                mov ax, cs:[si] 
                mov cs:[di], ax       (将EBF6写到s:处)   第二步
                
        s0: jmp short s
                
        s1: mov ax, 0                (3字节指令)
             int 21H                  (2字节指令)  
             mov ax, 0                (3字节指令)
                
        s2: jmp short s1            (2字节指令)  "EBF6" = JUMP -10(F6是补码,对应原码就是-10,执行jump前,IP会先指向下一条指令,所以编译器通过计算得知IP需要向上移动10个字节空间才能指向S1的位置,所以是EBF6) 第一步
   cs:ip -> nop                         

codesg ends
end start
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-3-17 14:03:02 | 显示全部楼层
:'(:);P
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-7-23 22:49:22 | 显示全部楼层
不正确
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-22 12:14

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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