| 
 | 
 
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册  
 
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 
 
操作系统经常会在我们看不到的地方修改内存数据(即便我们没打算这么做), 这点不必深究 
 
 
 
 
 |   
 
 
 
 |