. : : Assembly Language : : .  |  首页  |  我提出的问题  |  我参与的问题  |  我的收藏  |  消息中心   |  游客  登录  | 
刷新 | 提问 | 未解决 | 已解决 | 精华区 | 搜索 |
  《汇编语言》论坛 ->转移指令的原理
  管理员: assembly   [回复本贴] [收藏本贴] [管理本贴] [关闭窗口]
主题 : :  《实验8 分析一个奇怪的程序》的疑惑 求助  [待解决] 回复[ 5次 ]   点击[ 325次 ]  
sy3298444
[帖 主]   [ 发表时间:2011-11-29 17:35 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2011-10-24 17:04
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 



如上,我将s2处的"jmp short s1"换成了"jmp far ptr s1",但是在debug里面-u发现     "jmp far ptr s1"的机器码同样是EBF6(与"jmp short s1"所显示机器码一样)
这是什么原因呢?"jmp far ptr"应该是传递地址而不是位移啊?
我想原因可能是jmp short s1是2字节,而jmp far ptr s1是5字节的原因,随后将S的nop设为5个,又修改了S内的"mov ax,cs:[si]"使其将"jmp far ptr s1"能够传至S内,但debug内-u显示的机器码仍然是EBF3...
菜鸟求解
chinatree
[第1楼]   [ 回复时间:2011-11-29 19:03 ]   [引用]   [回复]   [ top ] 
荣誉值:118
信誉值:0
注册日期:2011-07-07 22:59
应该是因为s1相对于s2在-128范围内.是属于jmp near范围,所以,就算有far ptr来修饰,也是按near来算,你可以在s2前 加上 db 120 dup(?)就一看到,反汇编后是 jmp ????:????,嘿嘿
citong001
[第2楼]   [ 回复时间:2011-11-29 22:10 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2009-08-27 00:18
复制的是转移的位移数,向前,所以到了s处同样是向前转移,跑到返回指令处。
sy3298444
[第3楼]   [ 回复时间:2011-11-30 03:01 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2011-10-24 17:04
回复:[第1楼]
------------------
多谢啊 论坛里高手真多
chinatree
[第4楼]   [ 回复时间:2011-11-30 13:31 ]   [引用]   [回复]   [ top ] 
荣誉值:118
信誉值:0
注册日期:2011-07-07 22:59
jmp far ptr并不是位移,是标号的段:偏移。
sunnysong14
[第5楼]   [ 回复时间:2011-12-12 18:25 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2011-12-06 11:00
同意二楼的观点
需要登录后才能回帖 -->> 请单击此处登录
    Copyright © 2006-2024   ASMEDU.NET  All Rights Reserved