一个很困惑的问题:监测点2.3中ip为什么会被修改?每次变化多少?
本帖最后由 loop 于 2011-5-9 18:00 编辑监测点2.3中ip为什么会被修改?每次变化多少?为什么最后变为0?
http://www.fishc.com/uploads/allimg/101105/1_101105013345_1.jpg
指令要从CS段IP所指向的地方开始执行。
最开始的时候,指向 mov ax,bx这条指令,一般情况下,我们设置第一条指令的IP值为0000H
执行完第一条指令,IP的值会自动增加,以继续执行下一条指令,所以就改变了呀。mov ax,bx这条指令的机器码是:89D8 占用的是2个字节,所以IP为了执行下一条指令,就要+2,不知道我这样解释,你是否能明白。 能好的好的
对于指令的执行就会用到cs和ip,你懂的啊 也不需要知道什么指令所对应的代码的啊,你看指令是 sub ax,ax这里已经把ip的值弄成0 了的啊 看看路过,见识一下 本帖最后由 loop 于 2011-5-9 17:58 编辑
mov ax,bx ;读入指令缓冲器IP++
sub ax,ax;读入指令缓冲器IP++,sub命令把ax值清零了。
jmp ax;读入指令缓冲器IP++,执行jmp命令改变IP的值,IP++IP值变化了4次,因为ax=0,jmp把ax的值赋值给IP,所以最后IP为0 本帖最后由 风扫地 于 2011-5-9 19:37 编辑
subax,ax的意思就是 用ax里面的值减去ax里面的值再将结果(结果显然是0)送入ax中去 我看了这个也知道了我的一个疑问了,一个汇编指令对应的有一段机器代码的,机器代码占用了多少的字节,下面的ip就改变多少了,;P loop 发表于 2011-5-9 17:55 static/image/common/back.gif
IP值变化了4次,因为ax=0,jmp把ax的值赋值给IP,所以最后IP为0
mov ax,bx ;读入指令缓冲器IP++
sub ax,ax ;读入指令缓冲器IP++,sub命令把ax值清零了。
jmp ax ;读入指令缓冲器IP++,执行jmp命令改变IP的值,IP++
复制代码IP值变化了4次,因为ax=0,jmp把ax的值赋值给IP,所以最后IP为0
版主,这样解释的
但是jmp ax ;读入指令缓冲器IP++,执行jmp命令改变IP的值,IP++
在用jmp将ax=0赋给ip后,ip的值不是又改变了么,怎么还是0
因为ax的值是0,jmp ax 命令就是修改IP值的,所以当ax=0时,就等于把ax的值赋给IP,所以IP就=0 清晰明了多了 这里没有定义ax 是初始值是0啊,哪里来的0呢
页:
[1]