这个汇编我很迷!???
本帖最后由 百里狂生 于 2020-4-9 11:00 编辑assume cs:code,ss:stack
stack segment
dw 8 dup(0)
stack ends
code segment
start:
mov ax,stack
mov ss,ax
mov sp,16
mov ds,ax
mov ax,0
call word ptr ds:
inc ax
inc ax
inc ax
code ends
end start
为什么单步调试的时候,执行完mov ss,ax ,栈区(或data区)的值发生了改变?不是没有指令做修改吗?见图1
为什么call word ptr ds:执行完后,不是跳转到(ds:)所在的位置,而是一个不知道哪来的位子?见图2 为什么单步调试的时候,执行完mov ss,ax ,栈区(或data区)的值发生了改变?不是没有指令做修改吗?
因为你在用debug这个程序调试程序,debug这个程序要实现调试其他程序,需要用到中断机制,中断机制要用到栈
这个代码哪来的?要实现什么功能?
第二个问题我研究研究
在我这边
call word ptr ds:
这条call指令调用的是第一条指令
mov ax,stack
call word ptr ds:
这条指令转移的目标位置就是这个位置的值 ds:,是执行call之前的值,是push ip之前的值
在我这边,push ip之前 ds: 的内容是0,所以转移到了 0x16f0:0,而这个位置正好保存了第一条指令 mov ax,stack
这也不是绝对的,这里保存的也完全可以是其他指令
而且执行call指令之前,你用debug调试,debug用到了中断机制,中断机制用到了栈,也就是ds: 这个位置的值已经不是0,至于程序会转移到哪里,谁也不知道(或许这个值有规律?不重要了,^_^)
下面是我的调试过程,用了更高级的调试工具,bochs,debug做不到的事,bochs可以
人造人 发表于 2020-4-9 13:04
在我这边
call word ptr ds:
这条call指令调用的是第一条指令
非常感谢,终于知道原因了{:10_266:}
页:
[1]