美文网首页
汇编语言MASM:实验8分析一个奇怪的程序

汇编语言MASM:实验8分析一个奇怪的程序

作者: cyh老崔 | 来源:发表于2020-09-29 09:58 被阅读0次

一. 实验介绍

实验8 分析一个奇怪的程序

  • 分析下面的程序,在运行前思考:这个程序可以正确返回吗?

  • 运行后再思考:为什么是这种结果?

二. 实验代码

assume cs:codesg
codesg segment
    mov ax,4c00h
    int 21h
start: 
    mov ax,0
s:
    nop     ;nop 什么也不做占1个字节
    nop
 
    mov di,offset s     ;di 存放s的位移 8H
    mov si,offset s2    ;si 存放s2的位移20H 
    mov ax,cs:[si]      ;ax 存放 jmp short s1指令数据 EBF6(F6 = -9) 实质是往前移9个,
                        ;后面显示的jmp short s1 会转化成 jmp (ip)
    mov cs:[di],ax      ;将s:nop 存ax中的数据也就是 EBF6
s0:
    jmp short s ;跳转到标号s处执行指令 jmp 指令,为数据 EBF6 往偏移9个位置刚好是cs:0的位置,所以能正确返回
s1:
    mov ax,0
    int 21h
    mov ax,0
s2:
    jmp short s1    ;占2个字节
    nop
    
codesg ends
end start

三. 实验分析

代码是顺序结构进行从start标号开始执行,一直到s0 都没有进行任何的转移,执行到 jmp short s时 ,然后cs:ip又会指向标号s处的指令,为jmp 指令 数据为EBF6 ,其中F6代表要偏移的位置 转为有符号的8位二进制是-10 ,就是往前移10个字节(包含本身所占字节数) 刚好指向code段开始 翻译成jmp 指令就是 jmp 0!然后指向 mov ax,4c00,int 21h。所以程序可以正确的返回。

这里最重要的是要理解jmp 指令的本质,短转移它的二进制数的EBF6,F6代表的是偏移量,然而显示的jmp指令内容是 jmp (ip)!,(ip)会根据偏移量自动计算!所以赋值jmp指令内容 显示的汇编指令 是变动的,而二进制数却不是变动的。

image

image

总结:

  • s 处的指令赋值为: EBF6, EB开头的指令代表jmp, F6-9.
  • EBF6代表跳转到前面9字节处, 执行指令

四. 实验结果

能正确的结束程序:

image

参考:

https://blog.csdn.net/qq_29542611/article/details/79306304

相关文章

  • 汇编语言MASM:实验8分析一个奇怪的程序

    一. 实验介绍 实验8 分析一个奇怪的程序 分析下面的程序,在运行前思考:这个程序可以正确返回吗? 运行后再思考:...

  • Linux安装dosemu和masm

    最近在看王爽的《汇编语言》,需要做里面的一些实验,于是在Linux里安装了masm来练习。折腾了很久,查了很多东西...

  • 关于本文集的说明

    汇编语言根据CPU的架构可以分为不同的指令集,例如MIPS和MASM。本文集目前所有的内容都是关于MASM(Mic...

  • 汇编环境搭建

    对于一直想要学习汇编语言的我来说, 总是找不到一个理想的环境 上次软件安全课学会了使用MASM, 当时觉得这个工具...

  • 编写完整的汇编程序

    第一个完整的汇编程序 前面的实验都是利用Debug程序进行模拟测试的,并没有编写一个完整的汇编程序 使用汇编语言编...

  • 《汇编语言》实验8

    P187分析下面的程序,在运行前思考:这个程序可以正确返回吗?运行后再思考:为什么是这个结果? 分析: 这段代码执...

  • 使用汇编语言向屏幕打印内容

    【实验目的】使用汇编语言编写一段程序, 向屏幕中显示'Welcome to OS!'字符 【工具】 https:/...

  • 第2章 准备编程环境

    win32可执行程序的开发过程 编译器和链接器 MASM编译器 http://www.masm32.com/[ht...

  • 2019-09-14 MASM+VS:配置与控制台输出显示字符串

    新学期入门汇编语言,作业1就是用控制台输出个人信息。我选择的语言环境是MASM32+Visual Studio20...

  • 汇编语言 学习笔记(三)

    汇编语言学习笔记 四、汇编语言程序格式 语句基本格式 汇编语言程序中的语句由 4 项组成,格式如下: 名字(nam...

网友评论

      本文标题:汇编语言MASM:实验8分析一个奇怪的程序

      本文链接:https://www.haomeiwen.com/subject/txgsuktx.html