鱼C论坛

 找回密码
 立即注册
查看: 1516|回复: 2

第六章 实验5-1 有疑问0.0

[复制链接]
发表于 2015-6-12 19:32:08 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 酒鬼 于 2015-6-13 10:54 编辑

我在单步跟踪这一题的时后有一个疑问

我在:mov ax,stack
        mov ss,ax
        mov sp,16

SS得到我的栈地址后
SS:0B3E,SP:0010
我用 Debug 的D指令去查 d 0B3E:0000
Debug.png
在我画线的部份 为啥不是都为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:[0]
                push ds:[2]
                pop ds:[2]
                pop ds:[0]
                       
                mov ax,4c00h
                int 21h
code ends

        end Start
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2015-6-29 19:29:13 | 显示全部楼层
時隔多日,都沒人能回答我的一或呀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的值拉!!!!!!!!!!!!!

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-7-6 06:53:23 | 显示全部楼层
继续努力,加油
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-10-6 22:18

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表