用汇编语言实现字符的匹配

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

上海电力学院实验报告计算机硬件实验课程
题目:字符的匹配
班级:
姓名:
学号:
一.实验目的
1)掌握MASM工具调试汇编程序
2)熟悉DOS功能调用
3)学会用汇编语言编写程序,并掌握各功能号的作用
二.实验目的:
能够进行简单的功能程序的编辑操作
三.实验内容:
四.实验程序:
data segment 定义数据段
string db '12345' 定义要比较的字符
buffer db 40,0,40 dup(?) 定义一个数据缓冲区
string1 db 'yes!',0dh,0ah, '$' 定义匹配时显示yes
string2 db 'not match!',0dh,0ah, '$' 定义不匹配是显示not match
data ends 数据段定义结束
code segment 定义代码段
assume cs:code,ds:data
start: mov ax,0 初始化ds
mov ax,data
mov ds,ax
lea dx,buffer 在缓冲区的地址输入字符
mov ah,0ah
int 21h
mov si,dx 把缓冲区的地址给源串指针si add si,2 si加2是指针指向第一个字符 lea di,string 把目标串指针给 di
mov cx,5 设循环次数为5
CLD 指针按地址增量变化
repe cmpsb 执行串比较指令
jz right 完全相等则转right
lea dx,string2 否则显示not match
mov ah,09h
int 21h
jmp over 结束
right: lea dx,string1 显示yes
mov ah,09h
int 21h
jmp over 结束
over: mov ah,4ch
int 21h
code ends
end start
五.流程图:
开始(数据段、代码段定义)
Table=123456;string1=’no match ’;string2=’yes ’
定义string 10缓冲格
从键盘上输入要查询的数据段
Si=dx;di=table;cld
Repe cmpsb 重复比较
ZF=1

Right 跳转输出
Wrong 跳转输

回到DOS
结束
六.实验结果:
七.实验心得:
这次实验是前几次理论编写实验程序中最复杂的一个,刚开始我一个人做时并没有将它完整的做出来,而且感觉遇到问题颇多,后来通过与其他同学的合作谈论,这才得到实验结果,满足要求,只是到现在还留有一个问题,就是得到结果后会将前一句话覆盖,始终没解决掉。

相关文档
最新文档