第六章 实验5-1 有疑问0.0
本帖最后由 酒鬼 于 2015-6-13 10:54 编辑我在单步跟踪这一题的时后有一个疑问
我在:mov ax,stack
mov ss,ax
mov sp,16
SS得到我的栈地址后
SS:0B3E,SP:0010
我用 Debug 的D指令去查 d 0B3E:0000
在我画线的部份 为啥不是都为0 而是有数据在的???
我不是已经stack segment
dw 0,0,0,0,0,0,0,0
stack ends
声请好了8个字形数据的位置都为0麻??
assume cs:code,ds:data,ss:stack
data segment
dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h
data ends
stack segment
dw 0,0,0,0,0,0,0,0
stack ends
code segment
Start:
mov ax,stack
mov ss,ax
mov sp,16
mov ax,data
mov ds,ax
push ds:
push ds:
pop ds:
pop ds:
mov ax,4c00h
int 21h
code ends
end Start 時隔多日,都沒人能回答我的一或呀0.0
不過有一件值得慶幸的是
那就是經過了這麼多天,我已經學習到了 第十二章 內中斷
因為這樣我才終於在這一章中找到了當初的疑問的答案
在此分享一下~~
每當在Debug程序中 執行一次T指令
內部將會做以下事情
取得中斷類型碼N
pushf
TF,IF設置為0
push cs
push ip
IP = N*4
CS = (N*4)+2
最後在
iret
iret等於以下
pop IP
pop CS
popf
各位看出原因了嗎??
在我們輸入T指令,內部去執行完設置SS,SP的任務後
再跑去執行一些中斷代碼
其中就包括了最關鍵的
將標誌寄存器與CS,IP推入棧中保存起來
之後再將他們取出來
所以在執行完T指令後
我們的IP並沒有走位,依然是我們設定的數值
但棧裡面的值被改變了
也就是標誌寄存器與CS,IP的值拉!!!!!!!!!!!!!
继续努力,加油
页:
[1]