关于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
不知道上面这样写行不行呢?
看完上面问题的鱼友们一定是很在耐心的,谢谢你帮我解答哦。
问题一: jmp跳转有很多格式,就题目中的这种跳转而言,它是段内近转移,它计算出跳转的位移在转移,所以楼主说的是对的。
问题二:jmp不是只跳过指令,而是题目中的这种jmp short 标号 是段内近转移,只修改ip的值,而修改的范围是-128~127, 而题目中要求向下跳128b所以超出范围而越界,写在上面是可以的 努力学习 发表于 2012-3-4 11:49 static/image/common/back.gif
问题一: jmp跳转有很多格式,就题目中的这种跳转而言,它是段内近转移,它计算出跳转的位移在转移,所以楼 ...
好的。谢了哦。 xcxxcxcxcxc 问题一: jmp跳转有很多格式,就题目中的这种跳转而言,它是段内近转移,它计算出跳转的位移在转移,所以楼主说的是对的。
问题二:jmp不是只跳过指令,而是题目中的这种jmp short 标号 是段内近转移,只修改ip的值,而修改的范围是-128~127, 而题目中要求向下跳128b 所以超出范围而越界,写在上面是可以的
页:
[1]