【无涯契】【六】

本文探讨了一个在汇编语言编程中遇到的奇特现象:在执行CALL指令时,SS:[2]的内容会被意外修改。通过实验验证,发现即使初始值为0,执行后也会变为AB15。这揭示了CALL指令执行过程中的隐藏行为,超出了常规理解的简单堆栈操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    遇到一个很奇怪的问题。

   

DATAS SEGMENT
    dw 8 dup(0)
    ;此处输入数据段代码  
DATAS ENDS

STACKS SEGMENT
    ;此处输入堆栈段代码
STACKS ENDS

CODES SEGMENT
    ASSUME CS:CODES,DS:DATAS,SS:STACKS
START:
    MOV AX,DATAS
    MOV ss,AX
    mov sp,10h
    mov word ptr ss:[0],offset s
    mov ss:[2],cs
    call dword ptr ss:[0]
    nop   
    ;此处输入代码段代码
   S: MOV AH,4CH
    INT 21H
CODES ENDS
    END START

 

debug调试的结果为:

 

在执行call语句的时候, ss:[2] 里面的内容被改写了, 对此做了测试,发现当 ss:[2] 内容为0时,执行call指令后 其内容也会被写为 AB 15

估计这个内容值是ss的地址, 应该是执行call 指令的时候被压栈了,然而在王爽《汇编语言》中对于call指令只是简单的介绍为:

如: call 标号

先 push ip

 jmp  标号

对于ip地址值确实被压栈了,但是原先的栈段内容也有很多改变,即call指令其实不单单是做了这些东西,

或者说,栈段内容是因为cpu在执行指令中被改写的,这个改写是对call指令隐藏的。

对于这个问题,还是得继续深究一下。


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值