|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 cnlaolee 于 2021-2-5 21:06 编辑
学到栈章节,想试试,过程如下
-d:4000:0 20
4000:0000 00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00
4000:0010 00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00
4000:0020 00
-a
073f:0150 mov ax,4000
073f:0153 mov ds,ax
073f:0155 mov ax,1234
073f:0158 mov [0],ax
073f:015B
这几步是想再熟悉一下[address]同时变更4000:0 1数据,-t执行后,
-d 4000:0 20
4000:0000 34 12 00 00 00 00 00 00-00 00 00 00 00 00 00 00
4000:0010 00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00
4000:0020 00
可以看到4000:0 1已经按要求变了,但是下面
-a
mov ax,4000
mov ss,ax
mov sp,2
pop bx
-t执行后bx仍然是0000,再
-d 4000:0 20
4000:0000 68 01 3F 07 A3 01 00 00-00 00 00 00 00 00 00 00
4000:0010 00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00
4000:0020 00
用pop命令不仅没有把数据取出到BX,4000:0000~5数据也变了
用1000:,2000,3000,这样试都是这情况,请大家帮忙,多谢了
问题补充
在上面状况下,重复
mov ax,4000
mov ds,ax
mov ax,1234
mov [0],ax
命令,ax可以变成1234,但d 4000:0 3却发现没有变成34 12, 而是变成了76 01
我已经彻底晕菜了,请大家帮帮我
本帖最后由 wtchou 于 2021-2-5 09:14 编辑
sp指向的位置就是栈顶
要将 1234 pop 给bx , 栈顶要指向1234, 即sp=0
sp=2, 表示栈顶为4000:0002, 也就是指向1234后面的0000
操作系统经常会在我们看不到的地方修改内存数据(即便我们没打算这么做), 这点不必深究
|
|