博客园 首页 私信博主 显示目录 隐藏目录 管理 动画

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

实验任务1

任务1-1

对程序task1_1.asm进行汇编、连接,用debug加载、跟踪调试,基于结果,回答问题。
task1_1.asm

assume ds:data, cs:code, ss:stack

data segment
    db 16 dup(0)
data ends

stack segment
    db 16 dup(0)
stack ends
code segment
start:
    mov ax, data
    mov ds, ax

    mov ax, stack
    mov ss, ax
    mov sp, 16

    mov ah, 4ch
    int 21h
code ends
end start

实验结果

① 在debug中将执行到line17结束、line19之前,记录此时:寄存器(DS) = 076A ,寄存器(SS) = 076B ,寄存器(CS) = 076C 
② 假设程序加载后,code段的段地址是X,那么data段的段地址是 X-2H ,stack的段地址是 X-1H

任务1-2

对程序task1_2.asm进行汇编、连接,用debug加载、跟踪调试,基于结果,回答问题。
task1_2.asm

assume ds:data, cs:code, ss:stack

data segment
    db 4 dup(0)
data ends

stack segment
    db 8 dup(0)
stack ends
code segment
start:
    mov ax, data
    mov ds, ax

    mov ax, stack
    mov ss, ax
    mov sp, 8

    mov ah, 4ch
    int 21h
code ends
end start

实验结果

① 在debug中将执行到line17结束、line19之前,记录此时:寄存器(DS) =  076A ,寄存器(SS) =  076B ,寄存器(CS) =  076C 
② 假设程序加载后,code段的段地址是X,那么data段的段地址是 X-2H ,stack的段地址是 X-1H

任务1-3

对程序task1_3.asm进行汇编、连接,用debug加载、跟踪调试,基于结果,回答问题。
task1_3.asm

assume ds:data, cs:code, ss:stack

data segment
    db 20 dup(0)
data ends

stack segment
    db 20 dup(0)
stack ends
code segment
start:
    mov ax, data
    mov ds, ax

    mov ax, stack
    mov ss, ax
    mov sp, 20

    mov ah, 4ch
    int 21h
code ends
end start

实验结果

① 在debug中将执行到line17结束、line19之前,记录此时:寄存器(DS) =  076A ,寄存器(SS) =  076C ,寄存器(CS) =  076E 
② 假设程序加载后,code段的段地址是X,那么data段的段地址是 X-4H ,stack的段地址是 X-2H

任务1-4

对程序task1_4.asm进行汇编、连接,用debug加载、跟踪调试,基于结果,回答问题。
task1_4.asm

assume ds:data, cs:code, ss:stack
code segment
start:
    mov ax, data
    mov ds, ax

    mov ax, stack
    mov ss, ax
    mov sp, 20

    mov ah, 4ch
    int 21h
code ends

data segment
    db 20 dup(0)
data ends

stack segment
    db 20 dup(0)
stack ends
end start

实验结果

① 在debug中将执行到line9结束、line11之前,记录此时:寄存器(DS) =  076C ,寄存器(SS) = 076E ,寄存器(CS) =  076A 
② 假设程序加载后,code段的段地址是X,则data段的段地址是 X+2H ,stack的段地址是 X+4H

任务1-5

基于上述四个实验任务的实践、观察,总结并回答:
① 对于如下定义的段,程序加载后,实际分配给该段的内存空间大小是 16*ceil(N/16)

xxx segment
    db N dup(0)
xxx ends

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

答:
task1_4.asm正常运行,start为自定义的程序入口标号,可以缺省,若前面的start缺省,则后续的伪指令也可以改成end。
在task1_1.asm, task1_2.asm, task1_3.asm中,在code段中的指令之前有data段和stack段的定义,如果在将end start改成end,则程序运行时无法看到上述data段和stack段的定义指令,会出错。
而task1_4.asm中的所有指令都在start标号后,包括数据段与栈段的定义指令,正常运行。

实验任务2

编写一个汇编源程序,实现向内存单元b800:0f00 ~ b800:0f9f连续160字节,依次重复填充十六进制数
据03 04。

实验步骤

task2.asm

assume cs:code

code segment
start:
    mov ax, 0b800H
    mov ds, ax
    mov bx, 0f00H
    mov cx, 80

    s:    mov ds:[bx], 0403h
    inc bx
    inc bx
    loop s

    mov ax, 4c00H
    int 21H
code ends
end start

实验结果

实验任务3

已知8086汇编源程序task3.asm代码片段如下。
task3.asm

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:
   ; ×××
code ends
end start

实验要求:

① 编程实现把逻辑段data1和逻辑段data2的数据依次相加,结果保存到逻辑段data3中。
 ② 在debug中加载、反汇编、调试。在数据项依次相加前,和相加后,分别查看三个逻辑段data1, data2, data3对应的内存空间,确认逐一相加后,结果的确保存在了逻辑段data3中。
补充后的task3.asm:

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    ; ds:data1

    mov cx, 10
    mov bx, 0

  s:    mov ax, ds:[bx]
    add ax, ds:[bx + 0010H]

    mov ds:[bx + 0020H], ax
    inc bx
    loop s

    mov ax, 4c00H
    int 21H
code ends
end start

实验结果

实验任务4

已知8086汇编源程序task4.asm代码片段如下。
task4.asm

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 ah, 4ch
    int 21h
code ends
end start

实验要求:

 ① 补全程序,实现把逻辑段data1中的8个字数据逆序存储到逻辑段b中。
 ② 汇编、连接后,在debug中加载程序,运行到line15程序退出前,使用d命令查看数据段data2对应的内存空间,确认是否实现题目要求。
补充后的task4.asm

assume cs:code

data1 segment
        dw 2, 0, 4, 9, 2, 0, 1, 9
data1 ends

data2 segment
        dw 8 dup(0)
data2 ends

stack segment
    dw 8 dup(0)
stack ends

code segment
start:
    mov ax, stack
    mov ss, ax
        mov ax, data1
    mov ds, ax
    mov sp,16
    mov bx, 0
    mov cx, 8

  s1:
    push ds:[bx]
    add bx, 2
    loop s1

    mov ax, data2
    mov ds, ax
    mov bx,0
    mov cx, 8

  s2:
    pop ds:[bx]
    add bx, 2
    loop s2

        mov ah, 4ch
        int 21h
code ends
end start

实验结果

实验任务5

使用任意文本编辑器,录入汇编源程序task5.asm。
task5.asm

assume cs:code, ds:data
data segment
        db 'Nuist'
        db 2, 3, 4, 5, 6
data ends

code segment
start:
        mov ax, data
        mov ds, ax

        mov ax, 0b800H
        mov es, ax

        mov cx, 5
        mov si, 0
        mov di, 0f00h
s:      mov al, [si]
        and al, 0dfh
        mov es:[di], al
        mov al, [5+si]
        mov es:[di+1], al
        inc si
        add di, 2
        loop s

        mov ah, 4ch
        int 21h
code ends
end start

阅读源程序,从理论上分析源代码的功能,尤其是line15-25,循环实现的功能是什么,逐行理解每条指令的功能。

实验结果

1·对程序进行汇编、链接,得到可执行文件,运行并观察结果。

2·使用debug工具对程序进行调试,执行到程序返回前,即line25执行之后、line27执行之前,观察结果。

3·源代码中line19的作用是?
答:
改变字符的ASCII码值,将小写字母变为大写字母

4·修改line4里5个字节单元的值,重新汇编、链接、运行,观察结果。

db 2,3,4,5,6
--> 改成:
db 5 dup(2) 或 db 5 dup(5)


改变的是颜色参数

实验任务6

已知8086汇编源程序task6.asm代码片段如下。
task6.asm

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 ah, 4ch
   int 21h
code ends
end start

实验要求:

 ① 补全程序,将data段中的每行第一个单词从大写->小写。
 ② 在debug中加载程序,反汇编,执行到line13退出前,用d命令查看data段对应的内存空间,确认每行第一个单词已经由大写->小写。
补充后的task6.asm

assume cs:code, ds:data

data segment
    db 'Pink Floyd      ' ; 16字节
    db 'JOAN Baez       ' ; 16字节
    db 'NEIL Young      ' ; 16字节
    db 'Joan Lennon     ' ; 16字节
data ends

stack segment
    dw 8 dup(0) ; 8字, 16字节
stack ends

code segment
start:
    mov ax, data
    mov ds, ax

    mov ax, stack
    mov ss, ax
    mov sp, 0010H

    mov bx, 0
    mov cx, 4 ; 每行

s0:
    push cx     ;将外层循环的cx值压栈,在需要暂存数据时,一般选择栈
    mov si,0
    mov cx,4    ;内循环次数,第一个单词

s:
    mov ax, [bx + si]
    or  ax, 0020H ; ASCII码相差32
    mov [bx + si], ax
    inc si
    loop s

    add bx,16   ;程序的数据段是一块连续的内存,且bx一直为0,加上16指向下一个字符串
    pop cx      ;将栈顶的值传入寄存器cx中
    loop s0

    mov ah, 4ch
    int 21h
code ends
end start

实验结果

实验任务7

问题场景描述:
Power idea公司1975年-1979年的基本情况如下:

程序task7.asm的逻辑段data中(line4-6),已经定义好了这些数据。
task7.asm

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 ah, 4ch
    int 21h
code ends
end start

实验要求:

 ① 补全程序,实现题目要求,把年份、收入、雇员人数、人均收入,以结构化方式写入table段中。
 表格中,每行数据,在逻辑段table中占16个字节,各项数据占据字节大小分配如下。期中,数据之间用空格间隔。

② 汇编、连接后,在debug中加载、调试程序。灵活、合理使用u命令、g命令、d命令,显示刚开始逻辑段table的数据信息,以及,结构化存入数据后,数据段table的数据信息,确认实现题目要求。
补全后的task7.asm:

assume ds:data, es:table, cs:code

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 bx, 0
        mov cx, 5
        mov si, 0

s1:
    mov ax, ds:[bx]
       mov es:[si], ax
        add bx, 2
        add si, 2
        mov ax, ds:[bx]
        mov es:[si], ax
        add bx, 2
        add si, 000EH
loop s1

        mov bx, 20
        mov si, 5
        mov cx, 5

s2:
    mov ax, [bx]
        mov es:[si], ax
        add si, 2
        mov word ptr es:[si], 0
        add bx, 2
        add si, 000EH
loop s2

        mov bx, 30
        mov cx, 5
        mov si, 000AH
s3:
    mov ax, ds:[bx]
        mov es:[si], ax
        add bx, 2
        add si, 0010H

loop s3

        mov di, 30
        mov bx, 20
        mov cx, 5
        mov si, 000DH
s4:
    mov ax, ds:[bx]
        mov dx, 0
        div word ptr ds:[di]
        mov es:[si], ax
        add bx, 2
        add si, 0010H
        add di, 2
loop s4

        mov ah, 4ch
        int 21h
code ends
end start

实验结果

实验总结

循环的寄存器以及除法比较重要,编写时注意数据段和数据的长度

posted @ 2021-11-12 02:03  今天嘉然吃什么  阅读(28)  评论(3编辑  收藏  举报

致力于算法研究工作,喜爱交友,关注互联网前沿技术与趋势。


Font Awesome | Respond.js | Bootstrap中文网