计算机组成原理汇编字符串比较试验文.pdfVIP

计算机组成原理汇编字符串比较试验文.pdf

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验 6 汇编字符串比较试验 一、 实验目的 1. 了解汇编程序编写的格式 2. 熟悉汇编程序的编译、链接、运行的过程 3. 学会使用汇编语言的 dos 中断、字符串输入输出,以及对串的一些操作 二、 试验原理 1. 当 dos 中断为 21h 时,为 dos 系统功能调用。 此时,如果 AH 寄存器内的值为 0AH, 则由用户从键盘输入串到缓冲区。 输入的数据将保存在 DS段。DX 为缓冲区的首址, (DS:DX)=缓冲区最大字符数, (DS:DX+1)= 实际输入的字符数, (DS:DX+2)=串的 实际首地址。 2. 80X86 计算机, REPE指令为字符串比较指令,执行的操作为: ① 如(Count Reg)=0 或 ZF=0 (即某次比较的结果两个操作数不等 )时退出,否则 往下执行。 ② ( Count Reg)←(Count Reg)-1 ③ 执行其后的串指令 ④ 重复① ~③ 3. 80X86 计算机, CLD(clear direction flag) 指令使 DF=0,在执行串处理指令时,可使地 址自动增量。 三、 试验步骤 1. 在数据段定义两个字符串 String1 ,String2 2. 定义两个结果显示字符串 mess1 mess2 3. 保留 cpu 现场,将 ds ax 数据保存 4. 将 datas 赋给 ds, codes 赋给 cs ,stacks 赋给 ss 5. 将 String1 的首地址赋给 si, String2 的首地址赋给 di 6. 设置 flag 位为 0,对两个字符串进行比较 7. 对结果进行判断,并调用 dos 中断,输出显示不同的结果 (mess1 or mess2) 四、 实验结果与分析 实验代码如下: datas segment ;数据段 string1 db This is the String1. string2 db This is the String2. mess1 db Match!,13,10,$ mess2 db Not Match!,13,10,$ datas ends stacks segment ;堆栈段 stacks ends codes segments assume cs:codes,ds:datas,ss:stacks main proc far start: push ds ;保护当前 cpu 数据 sub ax,ax push ax mov ax,datas ;将 datas 赋给数据段 mov ds,ax move es,ax lea si,string1 ;将 string1 的偏移地址给 si lea di,string2 ;将 string2 的偏移地址给 di cld ;设置 flag 位为 0 串处理操作时地址会自动增量 mov cx,20 ;将字符串长度赋值给 cx 对比较次数记数 repz cmpsb ;串比较 jz match ;串相同 lea dx,mess2 ;串不同 jmp short disp match: lea dx,mes

文档评论(0)

ll17770603473 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档