Sing 发表于 2012-3-4 11:11:08

关于jmp一个小问题,求助

本帖最后由 Sing 于 2012-3-4 12:03 编辑

学到jmp时,遇到了一些不懂的地方,还请各位指教指教。

有一个程序如下:

assume cs:code
code segment
    start:jmp short s
            db 128 dup (0)
          s:mov ax, 0fffh
code ends
end start

说明:这是一个转移位移出现了越界的程序。

问题一,如何判断jmp指令往上跳还是往下跳呢?是不是看标号处在jmp指令的上面还是下面?是否如果标号在jmp上面,则往上跳,在jmp下面则往下跳。往上跳时是否jmp short s最多不能超过128,往下跳时是否最多不能超过127?
问题二,上面的程序中,jmp往下跳时,为什么没有跳过db 128 dup (0)这个操作符,反而程序还判断出了出现超界,这是不是说明jmp指令只跳过指令,比如只跳过mov ax, 0 之类的,对操作符不起作用。如果jmp指令真的只跳过指令,那上面程序操作符db 128 dup (0)能不能写在jmp short s 上面,写法如下:

         db 128 dup (0)
start: jmp short s

不知道上面这样写行不行呢?

看完上面问题的鱼友们一定是很在耐心的,谢谢你帮我解答哦。

努力学习 发表于 2012-3-4 11:11:09

问题一: jmp跳转有很多格式,就题目中的这种跳转而言,它是段内近转移,它计算出跳转的位移在转移,所以楼主说的是对的。
问题二:jmp不是只跳过指令,而是题目中的这种jmp short 标号 是段内近转移,只修改ip的值,而修改的范围是-128~127, 而题目中要求向下跳128b所以超出范围而越界,写在上面是可以的

Sing 发表于 2012-3-4 12:01:51

努力学习 发表于 2012-3-4 11:49 static/image/common/back.gif
问题一: jmp跳转有很多格式,就题目中的这种跳转而言,它是段内近转移,它计算出跳转的位移在转移,所以楼 ...

好的。谢了哦。

小宁 发表于 2012-3-4 12:37:38

xcxxcxcxcxc

key2046 发表于 2017-1-11 16:25:17

问题一: jmp跳转有很多格式,就题目中的这种跳转而言,它是段内近转移,它计算出跳转的位移在转移,所以楼主说的是对的。
问题二:jmp不是只跳过指令,而是题目中的这种jmp short 标号 是段内近转移,只修改ip的值,而修改的范围是-128~127, 而题目中要求向下跳128b  所以超出范围而越界,写在上面是可以的
页: [1]
查看完整版本: 关于jmp一个小问题,求助