[工学]微机原理实验汇编代码.docVIP

  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文档。上传文档
查看更多
[工学]微机原理实验汇编代码

实验三 分支和循环程序设计实验 一、分支结构设计实验 1.实验目的 (1)掌握分支程序的结构。 (2)掌握分支程序的设计、调试方法。 2、实验设备 装有MASM软件的IBM PC 机 3、实验内容 设计一数据块间的搬移程序 设计思想: 程序要求把内存中一数据区(称为源数据块)传送到另一存贮区(称为目的数据块)。源数 据块和目的数据块在存贮中可能有三种情况。对于两个数据块分离的情况,数据的传送从数据块的首址开始,或者从数据块的末址开始均可,但对于有部分重叠的情况,则要加以分析,否则重叠部分会因“搬移”而遭破坏。可以得出以下结论:当源数据块首址〉目的块首址时,从数据块首址开始传送数据。当源数据块首址〈目的块首址时,从数据块末地址开始传送数据。 因为书里已经有符合该要求的源代码,所以对于本程序主要是对其进行调试,源代码如下: DATA SEGMENT STRG DB 1000 DUP(?) STG1 EQU STRG+7 STG2 EQU STRG+27 STRSE EQU 50 DATA ENDS STACK SEGMENT PARA STACK STACK DB 100 DUP(?) STACK ENDS CODE SEGMENT ASSUME CS:CODE,DS:DATA,ES:DATA MAIN:MOV AX,DATA MOV DS,AX MOV ES,AX MOV CX,STRSE MOV SI,OFFSET STG1 MOV DI,OFFSET STG2 CLD PUSH SI ADD SI,STRSE-1 CMP SI,DI POP SI JL OK STD ADD SI,STRSE-1 ADD DI,STRSE-1 OK: REP MOVSB MOV AX,4C00H INT 21H CODE ENDS END MAIN 它的作用是把从第七个偏移量开始的50个存储单元中的内容,移动到从第27个偏移量开始的50个存储单元中。调试过程如下: 首先我们用T指令看看数据段的段基址是多少: 可以看到时08BB。然后我们运行一遍程序,结果数据段的各个数据如下: 因为数据是全0,所以是否发生了数据传送我们看不到。为了能看得到数据传送,我们用E指令把第七个数据起的8个数据修改为01、02、03、04、05、06、07、08: 然后我们再运行一遍程序,可以看到,数据发生了传送: 这是在运行中修改程序中的数据,我们也可以在源代码中修改,只要把STRG DB 1000 DUP(?)改为:STRG DB 7 DUP(?),01,02,03,04,05,06,07,08,992 DUP(?),这时候就不需要用E指令修改数据了。 最终运行结果也是: 二、循环程序设计实验 1.实验目的 (1)加深对循环结构的理解。 (2)掌握循环结构程序设计的方法。 (3)熟练掌握调试循环程序的方法。 2.实验设备 TDS-MD微机一台 3.内容 (1)编制程序使 S=1+2*3+3*4+4*5+……N(N+1),直到 N(N+1)项大于 200 为止。 这次没有现成的程序以供使用了,所以我编写了如下程序: DATA SEGMENT NUM DB 1000 DUP(?) DATA ENDS STACK SEGMENT PARA STACK STACK DB 100 DUP(?) STACK ENDS CODE SEGMENT ASSUME CS:CODE,DS:DATA,ES:DATA MAIN:MOV DX,0001H MOV BL,02H LOOP1:MOV AL,BL INC BL MUL BL ADD DX,AX CMP AX,200 JL LOOP1 MOV AX,4C00H INT 21H CODE ENDS END MAIN 程序流程图 程序的调试过程如下: 我们用T指令逐条运行程序,可以看到最终结果储存在寄存器DX中,为045F(十六进制),结果是正确的,说明程序编写无误: 如果要减少循环次数,我们可以对语句CMP AX,200进行修改。例如要求S=1+2*3+3*4+4*5中的S,可以把200改为20,再用T指令进行调试,结果如下: 答案是27(十六进制数),也就是十进制的39,与正确计算结果相符。 (2)求某个数据区内负数的个数

文档评论(0)

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

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

1亿VIP精品文档

相关文档