zoukankan      html  css  js  c++  java
  • 实验2 多个逻辑段的汇编源程序编写与调试

    实验2多个逻辑段的汇编源程序编写与调试

    一、实验目的

    1. 理解和掌握8086多个逻辑段的汇编源程序

    2. 理解和熟练应用灵活的寻址方式

    3. 通过汇编指令loop的使用理解编程语言中循环的本质,掌握其在嵌套循环中的正确使用

    4. 掌握使用debug调试8086汇编程序的方法

    二、实验准备

    复习教材5-8章:

    • 包含多个逻辑段的汇编源程序结构

    • 寻址方式

    • 汇编指令loop, div用法

    四、实验结论

    1. 实验任务1

    • 任务1-1
      • task1_1.asm源码
      • task1_1调试到line17结束、line19之前截图


    (与ss,sp相关的指令,都会一次执行两条)


    • 问题回答

      ① 在debug中将执行到line17结束、line19之前,记录此时:寄存器(DS) = 076A, 寄存器(SS)= 076B, 寄存器(CS) = 076C

      ② 假设程序加载后,code段的段地址是X,则,data段的段地址是_X-2_, stack的段地址是__X-1__。

    • 任务1-2

      • 任务task1_2.asm源码

      • task1_2调试到line17结束、line19之前观察寄存器DS, CS, SS值的截图

      • 问题回答

        ① 在debug中将执行到line17结束、line19之前,记录此时:寄存器(DS) = 076A, 寄存器(SS)= 076B, 寄存器(CS) = 076C

        ② 假设程序加载后,code段的段地址是X,则,data段的段地址是__X-2__, stack的段地址是__X-1__。

    • 任务1-3

      • 任务task1_3.asm源码
      • task1_3调试到line17结束、line19之前观察寄存器DS, CS, SS值的截图

    • 问题回答

      ① 在debug中将执行到line17结束、line19之前,记录此时:寄存器(DS) = 076A, 寄存器(SS)= 076C, 寄存器(CS) = 076E

    • ② 假设程序加载后,code段的段地址是X,则,data段的段地址是__X-4__, stack的段地址是__X-2__。

    • 任务1-4

      • 任务task1_4.asm源码
      • task1_4调试到line17结束、line19之前观察寄存器DS, CS, SS值的截图

    • 问题回答

      ① 在debug中将执行到line9结束、line11之前,记录此时:寄存器(DS) = 076C, 寄存器(SS) =076E, 寄存器(CS) = 076A

      ② 假设程序加载后,code段的段地址是X,则,data段的段地址是__X+2__, stack的段地址是__X+4__。

      结论: 所有的逻辑段公平的分配空间,按照书写顺序分配16*K的空间,如果代码段写在前面,则代码段先赋予一定的空间。

    • 任务1-5

      基于上述四个实验任务的实践、观察,总结并回答:

      ① 对于如下定义的段,程序加载后,实际分配给该段的内存空间大小是 N/16向上取整*16个字节

      xxx segment
      	db N dup(0)
      xxx ends
      

      ② 如果将程序task1_1.asm, task1_2.asm, task1_3.asm, task1_4.asm中,伪指令 end start 改成end , 哪一个程序仍然可以正确执行。结合实践观察得到的结论,分析、说明原因。

      程序1,2,3都会报错,如果不写start,程序并不知道程序段的执行入口在哪里,会默认是数据段的首地址,而程序4原本就代码段写在最前面,所以不会报错。

    2. 实验任务2

    • 汇编源代码

    • 运行结果截图

    任务1.(ay17)

    assume cs:code
    code segment
    	mov ax,0b800H
    	mov ds,ax
    	mov ax,80
    	mov cx,ax
    	mov bx,0f00H
    s:	mov byte ptr ds:[bx],3H
    	inc bx
    	mov byte ptr ds:[bx],4H
    	inc bx
    	loop s
    	
    	mov ax,4c00h
    	int 21h
    code ends
    end
    

    任务2


    部分数据无法修改,估计修改到了只读存储器。


    3. 实验任务3

    要求:

    ① 编程实现把逻辑段data1和逻辑段data2的数据依次相加,结果保存到逻辑段data3中。

    assume cs:code
    data1 segment
        db 50, 48, 50, 50, 0, 48, 49, 0, 48, 49 ; ten numbers
    data1 ends
    
    data2 segment
        db 0, 0, 0, 0, 47, 0, 0, 47, 0, 0       ; ten numbers
    data2 ends
    
    data3 segment
        db 16 dup(0)
    data3 ends
    
    code segment
    start:
    	mov ax,data1
    	mov ds,ax
    	mov cx,10
    	mov bx,0
    s: 	mov ax,[bx]
    	add ax,[bx+16]
    	mov [bx+32],ax
    	inc bx
    	loop s
    	mov ah,4ch
    	int 21h
    code ends
    end start
    

    ② 在debug中加载、反汇编、调试。在数据项依次相加前,和相加后,分别查看三个逻辑段data1,

    data2, data3对应的内存空间,确认逐一相加后,结果的确保存在了逻辑段data3中。

    编译截图:

    原图:

    修改后的数据域

    4. 实验任务4

    补充完整后的汇编源代码

    • 在debug中加载、反汇编、调试截图

    • 要求给出,在程序退出前,使用d命令查看数据段data2对应的内存空间的截图。

    程序补全
    assume cs:code
    
    data1 segment
        dw 2, 0, 4, 9, 2, 0, 1, 9
    data1 ends 
    
    data2 segment
        dw 8 dup(?)
    data2 ends
    
    code segment
    start:
        mov ax,data1
    	mov ds,ax
    	mov bx,0
    	mov cx,8
    s:  mov ax,[bx]
    	push ax
    	inc bx
    	inc bx
    	loop s	
    	mov cx,8
    s1: pop [bx]
    	inc bx
    	inc bx
    	loop s1
    	
        mov ah, 4ch
        int 21h
    code ends
    end start
    
    debug截图

    实验结果

    5. 实验任务5

    • task5.asm源码

    • 运行结果截图

    • 使用debug工具对程序进行调试,使用g命令一次性执行到程序返回前(即ine25执行之后、line27执行之前)的截图

    • 源代码中line19的作用是?

    • 源代码中data段line4的字节数据的用途是?

    运行接口截图:

    问题1: line19的作用

    通过与运算,实现小写到大写的转换。

    问题2:line4字节数据的作用

    使得字符显示出不同的颜色。第四行的数据在每次输出一个字符之后就跟着写入,估计是控制字符颜色的。

    6. 实验任务6

    • task6.asm源代码

    • 在debug中加载、反汇编、调试截图

      要求给出,在程序退出前,使用d命令查看数据段data对应的内存空间的截图。

    源代码
    assume cs:code, ds:data
    
    data segment
        db 'Pink Floyd      '
        db 'JOAN Baez       '
        db 'NEIL Young      '
        db 'Joan Lennon     '
    data ends
    
    code segment
    start:
       mov ax,data
       mov ds,ax
       mov cx,4
       mov bx,0
    s: mov al,[bx]
       or al,20H
       mov [bx],al
       add bx,16
       loop s
       mov ah, 4ch
       int 21h
    code ends
    end start
    
    编译的截图:

    实验截图

    7. 实验任务7

    • task7.asm源码

    • 调试截图

      • 查看table段原始数据信息截图
      • 在debug中运行到程序退出之前,使用d命令查看table段对应的内存空间的截图,确认信息是否按要求结构化地写入到指定内存
    源码
    assume cs:code, ds:data, es:table
    
    data segment
        db '1975', '1976', '1977', '1978', '1979' 
        dw  16, 22, 382, 1356, 2390
        dw  3, 7, 9, 13, 28 
    data ends
    
    table segment
        db 5 dup( 16 dup(' ') )  ;
    table ends
    
    code segment
    start:
    	mov ax,table
    	mov es,ax
    	mov ax,data
    	mov ds,ax
    	mov cx,5
    	mov bx,0
    	mov si,0
    s:  mov ax,ds:[bx]
    	mov es:[si],ax
    	mov ax,ds:[bx+2]
    	mov es:[si+2],ax
    	add bx,4
    	add si,16
    	loop s
    	mov cx,5
    	mov si,0 
    	mov bx,0
    s1: mov ax,ds:[bx+20]
    	mov es:[si+5],ax
    	mov ax,ds:[bx+25]
    	mov es:[si+10],ax
    	add si,16
    	add bx,2
    	mov ax,ds:[bx+20]
    	div byte ptr ds:[bx+25]
    	mov es:[si+13],al
    	loop s1
    	
    
    code ends
    end start
    
    table的原始数据

    实验结果

  • 相关阅读:
    使用Python学习RabbitMQ消息队列
    Python调用nmap扫描网段主机信息生成xml
    扫描网站服务器真实IP的小脚本
    C语言实现将彩色BMP位图转化为二值图
    Python socket编程之构造IP首部和ICMP首部
    ARP协议抓包之帧长度和Gratuitous ARP的问题
    合天解密200-找茬游戏
    合天misc100
    IDF实验室-简单的js解密
    IDF实验室—不难不易的js加密
  • 原文地址:https://www.cnblogs.com/hjw201983290498/p/15525012.html
Copyright © 2011-2022 走看看