(1)程序如下
assume cs:code
data segment
?
data ends
code segment
start: mov ax,data
mov ds,ax
mov bx,0
jmp word ptr [bx+1]
code ends
end start
若要使程序中的jmp指令执行后,CS:IP指向程序的第一条指令,在data段中应该定义哪些数据?
分析:jmp word ptr [bx+1] 是段内转移指令,在执行jmp指令后,cs不变,ip变为0 即指向start位置处(第一条指令)
jmp word ptr x 从内存单元地址处开始存放一个字,是转移的目的偏移地址
因此只需要 bx+1 位置处的值为0即可,即从第二个字节开始后一个字要为0(或者第二、第三个字节为0,或者设置一个双字为0也可以)
因此答案为 db 3 dup(0) (第一个字节可以为任意值)
或者 dw 2 dup(0)
或者 dd 0
实验结果可以看到 ip由 0008 转变为 0001,转到了 mov ax,data 指令处

(2) 程序如下

文章讲述了如何使程序中的jmp指令执行后CS:IP指向程序的起始,涉及段内转移指令、数据段和代码段的设置,以及Debug工具在内存查看中的应用。
6600

被折叠的 条评论
为什么被折叠?



