Java教程

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

本文主要是介绍实验2 多个逻辑段的汇编源程序编写与调试,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

实验任务1

任务1-1

源程序代码:

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

data segment 
    db 16 dup(0)         ;预留16个字节单元,初始值均为0 
data ends 

stack segment 
    db 16 dup(0)         ;预留16个字节单元,初始值均为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-2__, stack的段地址是__X-1__

 

任务1-2

 

源程序代码:

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

data segment 
    db 4 dup(0)     ; 预留4个字节单元,初始值均为0 
data ends 

stack segment 
    db 8 dup(0)     ; 预留8个字节单元,初始值均为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-2__, stack的段地址是__X-1__。

 

任务1-3

 

源程序代码:

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

data segment 
    db 20 dup(0)     ; 预留20个字节单元,初始值均为0 
data ends 

stack segment 
    db 20 dup(0)     ; 预留20个字节单元,初始值均为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-4__, stack的段地址是__X-2__.

 

任务1-4

 

源程序代码:

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+2__, stack的段地址是_X+4__。

任务1-5

①    对于如下定义的段,程序加载后,实际分配给该段的内存空间大小是 16*ceil(N/16) .

②    task1_4.asm仍然可以正确执行,因为end后面说明了原程序的入口,若为空那么程序将从从头开始执行,只有task1_4的一开始就是代码段的内容。

实验任务2

源程序代码:

assume cs:code

code segment
start:
    mov ax,0b800h
    mov ds,ax
    mov bx,0f00h
    mov cx,80

s:  mov [bx],0403h
    add bx,2
    loop s

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

 

 

实验任务3

源程序代码:

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 ax,data2
    mov es,ax
    mov bx,0
    mov cx,10
s:  mov al,[bx]
    add es:[bx],al
    inc bx
    loop s
    mov ax,data3
    mov ds,ax
    mov bx,0
    mov cx,10
s0: mov al,es:[bx]
    mov [bx],al
    inc bx
    loop s0

mov ax,4c00h
int 21h
code ends
end start

 初始状态:

 

 执行完成后:

 

实验任务4

源程序代码:

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 ax, data2
    mov ss, ax
    mov sp, 16
    mov bx, 0
    mov cx, 8
  s:push [bx]
    add bx, 2
    loop s

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

执行前后

 

 

实验任务5

源程序代码:

assume cs:code, ds:data
data segment
        db 'Nuist'
        db 5 dup(5)
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

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

 line15设置循环次数为5,即NUIST字符个数,第16、17行分别设置数据段和显存地址偏移量的初始值,第18、19行将数据段中的内容复制到寄存器ax中,并全部字符转换成大写,第20行将寄存器ax中的值送到显存地址空间,第21、22行将数据段后五个字节分别送到显存地址空间中与前五个字符相邻的单元中,用来设置每个字符的颜色。

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

 这里的数值是用来设置显示字符的颜色

实验任务6

程序源代码:

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 dx,cx
   mov cx,4
   mov si,0
    s0:
        mov al,ds:[bx+si]
        or al,00100000B
        mov ds:[bx+si],al
        inc si
   loop s0
   add bx,16
   mov cx,dx
   loop s
   mov ah, 4ch
   int 21h
code ends
end start

 程序执行前后:

 

 

实验任务7

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, data
    mov ds, ax
    mov ax, table
    mov es, ax
    mov bx, 0
    mov si, 0
    mov cx, 5

 s0:mov ax, ds:[bx]
    mov es:[si], ax
    mov ax, ds:[bx+2]
    mov es:[si+2], ax
    add bx, 4
    add si,10h
    loop s0

    mov bx, 20  ;跳过年份的20个字节
    mov si, 5
    mov cx, 5
 s1:mov ax, ds:[bx]
    mov es:[si], ax
    mov word ptr es:[si+2], 0   ;收入字段的高址部分设为0
    add bx, 2
    add si, 10h
    loop s1

    mov cx, 5
    mov si, 10
    mov bx, 30
 s2:mov ax, ds:[bx]
    mov es:[si], ax
    add bx, 2
    add si, 10h
    loop s2

    mov si, 0
    mov cx, 5
 s3:mov ax, es:[si+5]   ;被除数低16位,放在ax中
    mov dx, es:[si+7]   ;高16位,放在dx中
    div word ptr es:[si+10]
    mov es:[si+13], ax    ;将商移入位置

    add si, 10h
    loop s3

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

 

 

 

 

 

 

 

这篇关于实验2 多个逻辑段的汇编源程序编写与调试的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!