汇编语言检测点10.5求解

在call语句时,cpu压入ip,地址是ss:[0eh],然后jmpwordptrds:[0eh]。我的理解是:cpu压入IP的堆栈地址是ss:[0eh],而jmpwor... 在call语句时,cpu压入ip ,地址是ss:[0eh],然后jmp word ptr ds:[0eh]。我的理解是:cpu压入IP的堆栈地址是ss:[0eh],而jmp word ptr ds:[0eh]偏移也是0eh,且ds=ss,按我的分析应该接着执行下面的inc ax。
可是为何网上答案都是说ip会等于0? 虽然最终答案是对的,可是这个原理我不懂,请高手指教!!!
assume cs:code

stack segment
dw 8 dup (0)
stack ends

code segment
start:mov ax,stack
mov ss,ax
mov ds,ax
mov sp,16
mov ax,0
call word ptr ds:[0eh]
inc ax
inc ax
inc ax

mov ax,4c00h
int 21h

code ends
end start
展开
 我来答
匿名用户
2015-03-16
展开全部
stack segment
dw 8 dup (0)
stack ends
申明了一个栈段 分配大小是 8个DW 大小的空间 并且全部初始化为 0
ds==ss==stack segment的首地址
call word ptr ds:[0eh] ;call 的是stack segment首地址+0eh 单元中的内容作为地址(为初始化时的0)调用,即call 了一个地址为0的去执行了!
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式