• 实验 3 编程、编译、连接、跟踪


    一、实验内容

    1、练习1

    第 1 步,编写汇编源程序 t1.asm, 源程序代码下图 所示:

    assume  cs:code
    code segment
        mov ah,2
        mov dl,3
        add al,30h
        int 21h
      
        mov ah,2
        mov dl,6
        add dl,30h
        int 21h
    
        mov ah,4ch
        int 21h
    code ends
    end

    第 2 步,对源程序 1.asm 进行汇编、连接、运行、调试

    (1) 运行程序,观察程序输出结果是什么?

      1.在edit中编辑程序,输入源代码,保存为.asm文件,命名为1.asm

      2.对 1.asm文件进行编译,得到 1.obj文件

      3.对 1.obj进行连接,生成1.exe文件

      4.执行exe文件,得到程序运行结果

    (2) 将 line4 和 line9 种寄存器 dl 的值分别修改为 0~9 中任何一个数字,重新汇编→ 连接→运行,观察结果的变化。

      1.输入源程序代码,将line4改为mov dl,5 ,line9改为mov dl,8,生成.asm文件,命名为2.asm

      2.对2.asm进行汇编、连接、运行,得到运行结果

    (3) 用 debug 对生成的可执行文件 t1.exe 进行调试。

      1 使用 r 命令查看。观察寄存器 cx 的值是 多少;观察寄存器 ds 和 cs 的值是多 少,它们之间是否满足关系(cs)=(ds)+10H?

     

      满足  (cs)=(ds)+10H  

      2 PSP(程序段前缀)的头两个字节是 CD 20, 用 debug 查看 PSP 的内容,验证是否 如此。

      3 使用 u 命令对 t1.exe 进行反汇编,观察反汇编得到的源代码。

     

      4 使用 t 命令和 p 命令(遇到 int 命令时,用 p 命令)单步调试,观察结果。

    2. 练习 2

      1.编写汇编源程序 t2.asm,源程序代码如下图

    assume cs:code
    code segment
        mov ax,0b800h
        mov ds,ax
    
        mov bx,0
        mov [bx],0433h
        
        add bx,2
        mov [bx],0436h
    mov ax,4c00h int 21h code ends end

       2.编译、连接、运行过程同练习1,得到运行结果,在屏幕左上方出现红色的数值 36。

      3.重新打开t2.asm,将源代码中line7的0433h→0432h,line10 的 0436h→0439h, 然后重新汇编、连接,得到可执行文件 t2.exe。使用 cls 命令清

    屏后,程序运行结果得到:在屏幕左上方出现红色的数值 29。

     4.重新打开t2.asm,将源代码中 line7 的 0433h→0333h,line10 的 0436h→0336h,然后重新汇编、连接,得到可执行文件 t2.exe。使用 cls 命令清屏后,得到程序运行结果得到:在屏幕左上方出现蓝色的数值 36。

     

    二、总结与体会

     将练习二与实验一中的实验任务四进行比较,两者都是控制显示输出。在练习二的操作中,据我猜测,对于0436h,4控制颜色,36控制形状。

     关于p命令:类似t命令,若有子程序,直接执行完子程序全部指令而不是逐条执行指令,在遇到循环指令时,会直接执行至CX递减至0。

  • 相关阅读:
    [ ERROR ] Error in test library 'pymysql': Creating keyword 'Connect' failed: Keyword with same name defined multiple times.
    【robotframework】pycharm+robotframe(转)
    Django 配置mysql遇到问题(一)
    Django 初始化数据库遇到问题(python manage.py migrate)
    连接mysql报"ERROR 1130: Host xxx.xxx.xxx.xxx is not allowed to connect to this MySQL server"
    性能测试-MySQL性能查看(转)
    APP安全测试
    在线java堆栈分析工具
    性能-如何根据线程和进程找到性能瓶颈或者问题点
    Jmeter CSV参数带汉字处理
  • 原文地址:https://www.cnblogs.com/Xingxixi/p/9971743.html
Copyright © 2020-2023  润新知