第06章(简化)分解.pptVIP

  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章 微型计算机的程序设计 6.1 程序设计步骤 6.2 简单程序 6.3 分支程序 6.4 循环程序 6.5 子程序 6.6 查表程序 习题 6.1 程序设计步骤 6.2 简单程序 这种程序的形式最简单,计算机执行程序的方式是“从头到尾”,逐条执行指令语句,直到程序结束。 这类简单程序不用按上述7个步骤,可直接对给出的题目写出助记符程序清单。 【例6.1】用数据运算指令,对两个16位数做加法运算。这两个数从地址10050H开始连续存放,低位在小地址一端,结果放在这两个数之后。 (1) 分析题目:它是一个16位数相加的问题。在用加法指令时,必须要考虑低8位和低8位相加后产生的进位问题。 (2) 根据86系列指令系统,可以直接对累加器AX做字操作,但在低位相加后,会影响标志寄存器的进位位CF, 所以,要用带进位的加法指令。 (3) 绘制程序流程图,如右图所示。 (4) 内存空间分配:被加数、加数及和在内存的空间分配见下表  (5) 编制的程序如下: MOV AX,1000H    MOV DS,AX   ; DS=1000H   MOV SI,50H    ; 被加数指针SI=50H   MOV DI,52H    ; 加数指针DI=52H   MOV BX,54H    ; 和的指针BX=54H  CLC        ; 清CF   XOR AX,AX    ; 清AX   MOV AX,[SI]  ; 取一个字到AX  ADC AX,[DI]  ; AX←AX+[DI]+CF   MOV [BX],AX  ; 存一个字到[BX]   HLT   ; 暂停  【例6.2】将内存(10050)单元的内容拆成两段,每段4位,并将它们分别存入内存(10051)和(10052)单元。即(10050)单元中的低4位放入(10051)的低4位,(10050)单元中的高4位放入(10052)的低4位,而(10051)和(10052)的高4位均为零。 (1) 分析题目:这个题目提出的任务在十六进制显示及二、十进制计算中常遇到的. 现在假设内存(10050)中放着7AH,则题目要求就是把7AH拆成07H和0AH两部分,并把0AH放在(10051)单元,07H放在(10052)单元。 在拆字时,想取得一个数的前4位和后4位可以用移位指令的方法,也可以用逻辑与一个0F0H(二进制和逻辑与一个0FH(二进制的办法。 (2) 根据指令系统中含有的指令,先取出该数用逻辑指令与上一个 0FH,得到低4位,存入内存。再取出该数用移位指令逻辑右移SHR(见图5.10(c))4次,取得高4位,存入内存即可. (3) 绘制程序流程图,如图6.3所示。 (4) 内存空间分配:把7AH拆成07H和0AH两部分,它们在内存空间的分配情况见下页表6.2。 (5)编制的程序如下: MOV AX,1000H MOV DS,AX ;DS=1000H MOV SI,50H ;需拆字节的指针SI=50H MOV AL,[SI] ;取一个字节到AL中 AND AL,0FH ;把AL的前4位清0 MOV [SI+1],AL ;把得到的后4位放到(10051)单元 MOV AL,[SI] ;再取出需拆字节放到AL中 MOV CL,4 SHR AL,CL ;逻辑右移四次,前4位补0 MOV [SI+2],AL ;放入(10052)单元 6.3 分支程序 【例6.3】求AX累加器和BX寄存器中两个无符号数之差的绝对值,结果放在内存(2800)单元中。 (1) 分析题目:此题目中,AX累加器和BX寄存器中的数是不知道的。对两个不知大小的数相减并求绝对值,显然应该先解决哪一个值稍大些,然后再用大数减小数的方法,才可求得绝对值。 (2) 根据指令系统中的比较指令,编出判断大小的环节,即可解决问题,图6.5即为该例题的程序流程图。 (3) 根据流程图编制程序如下:    CLC       ; 清除CF    SUB AX,BX  ; AX←AX-BX    JC AA  ; CF=1转AA去执行(即AX<BX时转移)    MOV DI,2800H

文档评论(0)

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

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

1亿VIP精品文档

相关文档