实验1. 综合使用 loop,[bx],编写完整汇编程序,实现向内存 b800:07b8 开始的连续 16 个 字单元重复填充字数据 0403H。

1.编写指令

assume cs:code
code segment
    mov ax,0b800h
    mov ds,ax
    mov bx,07b8h
    mov cx,16
s:  mov [bx],0403h
    add bx,2
    loop s

    mov ax,4c00h
    int 21h
code ends
end

2.编译,链接,执行

将源代码程序中字数据 0403H→修改为 0441H,再次运行,截图显示运行结果:

实验2

1.代码编写

assume cs:code
code segment
    mov ax,0020h
    mov ds,ax
    mov bx,0
    mov ax,0
    mov cx,64
 s: mov [bx],al
    add bx,1
    add al,1
    loop s

    mov ax,4c00h
    int 21h
code ends
end

2.)汇编、链接无误后,灵活使用 debug 的 t 命令、g 命令、p 命令调试,用 d 命令 查看 0:200~0:23F,确认是否将 0~63 传送至此段内存区域

实验3

assume cs:code
code segment
    mov ax,cs     mov ds,ax
    mov ax,0020h
    mov es,ax
    mov bx,0
    mov cx,0  
 s: mov al,[bx]
    mov es:[bx],al
    inc bx
    loop s

    mov ax,4c00h
    int 21h
code ends
end

该段实际上是将[bx]中的数据传入到0:200处,那也就是说ds中存放的应该是程序段的段地址,也就是cs的值,所以将ds赋值为cs。

cx的值为loop循环的次数,在执行本实验时,指令的复制实际上还是向内存单元写入数据,所以程序段的长度决定了要写入数据长度,即循环写入的次数,所以cx的值即为程序段的长度。

所以先赋值cs为0,再用r命令查看cx寄存器的值,用u命令反汇编查看mov ax,4c00h,int 21h两条指令的长度,用cx初始值减去这两条指令的长度

2.用r命令查看一开始cx的值,再用u命令反汇编:

复制的指令长度为001C-5=0017h

3.修改cx的值为0017h:

可以利用u命令反汇编观察到指令确实被写入了内存0:200处

posted on 2018-11-18 17:06  123冰水泡面  阅读(248)  评论(2编辑  收藏  举报