标签:显示 循环 内存区域 oop info inf 技术 查看 bubuko
实验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处
标签:显示 循环 内存区域 oop info inf 技术 查看 bubuko
原文地址:https://www.cnblogs.com/hongyezhu/p/9978458.html