百里狂生 发表于 2020-4-9 10:36:03

这个汇编我很迷!???

本帖最后由 百里狂生 于 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

人造人 发表于 2020-4-9 12:12:33

为什么单步调试的时候,执行完mov ss,ax ,栈区(或data区)的值发生了改变?不是没有指令做修改吗?
因为你在用debug这个程序调试程序,debug这个程序要实现调试其他程序,需要用到中断机制,中断机制要用到栈

人造人 发表于 2020-4-9 12:15:17

这个代码哪来的?要实现什么功能?

第二个问题我研究研究

人造人 发表于 2020-4-9 13:04:18

在我这边
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 14:54:31

人造人 发表于 2020-4-9 13:04
在我这边
call word ptr ds:
这条call指令调用的是第一条指令


非常感谢,终于知道原因了{:10_266:}
页: [1]
查看完整版本: 这个汇编我很迷!???