汇编语言检测点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 展开
可是为何网上答案都是说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 展开
1个回答
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的去执行了!
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的去执行了!
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询