微机原理7_汇编语言程序设计08课件.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
微机原理7_汇编语言程序设计08课件

第七章 汇编语言程序设计;7.1 汇编语言程序设计的一般步骤;7.1.1 流程图 1.流程图的概念 流程图是由特定的几何图形、指向线、文字说明来表示数据处理的步骤,形象描述逻辑控制结构以及数据流程的示意图。流程图具有简洁、明了、直观的特点。 ;(2)判断框 ;(5)指向线 ;7.1.2 程序结构;7.2 程序设计 ;复应车榆舆恒软仓赤渗烃髓巫操戎段毒牙节间半虱帝堕甸牙赢档努恍都笨微机原理7_汇编语言程序设计08课件微机原理7_汇编语言程序设计08课件; 源程序如下: DATA SEGMENT X DW 200 Y DW 100 Z DW 3000 V DW 10000 W DW 2 DUP(?) DATA ENDS STACK SEGMENT STACK DB 200 DUP(0) STACK ENDS CODE SEGMENT ASSUME DS:DATA,CS:CODE,SS:STACK ;START: MOV AX,DATA MOV DS,AX ;DATA→AX MOV AX,X IMUL Y ;(X)*(Y)→DX:AX MOV CX,AX MOV BX,DX ;(DX:AX)→(BX:CX) MOV AX,Z CWD ;(Z)符号扩展 ADD CX,AX ADC BX,DX ;(BX:CX)+(DX:AX)→(BX:CX) SUB CX,540 SBB BX,0 ;(BX:CX)-540→(BX:CX) MOV AX,V ;CWD ;(V)符号扩展 SUB AX,CX SBB DX,BX ;(DX:AX)-(BX:CX)→(DX:AX) IDIV X ;(DX:AX)/X MOV W,AX ;商→W MOV W+2,DX ;余数DX→W+2 MOV AH,4CH INT 21H CODE ENDS ;退出DOS 状态 END START ;7.2.2分支程序设计;1. 单分支类型 ;AX≥0 ?;2.双分支程序 ;双分支举例:显示BX的最高位。 shl bx,1 jc one ;转分支体 mov dl,’0’ ;分支体1 jmp next ;转后续操作 One: mov dl,’1’ ;分支体2 next: mov ah,2 ;后续操作 int 21h 分支程序的其他问题 ⑴有些双分支问题可以先假设一种情况,把双分 支改成单分支问题。如上例,先假设BX最高位为0, 在分支外准备显示0;如最高位为0,即可直接跳到后 续操作;如最高位为1才需要执行分支体。;3.多分支程序;例4-19(p149)数据块传送程序 DATA SEMENT STRG DB 1000 DUP (?) STG1 EQU STRG+7 STG2 EQU STRG+25 STRSE EQU 50 DATA ENDS STACK SEGMENT PARA STACK ‘STACK’ STRN DB 100 DUP (?) STACK ENDS COSEG SEGMENT ASSUME CS:COSEG,DS:DATA,ES:DATA,SS:STACK BBEGIN: 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 JB OK STD ADD DI,STRSE-1 ADD SI,STRSE-1 OK:REP MOVSB MOV AH,4CH INT 21H COSEG ENDS END BEGIN; 循环程序设计 ;7.2.3 循环程序设计(重复执行的程序段)p154 1.循环程序的组成 初始化部分:设置循环条件、次数、初值等。 循环体部分:重复执行的代码,含循环条件的修改等。 循环控制部分:判断循环条件,决定是否继续。 2.两种循环结构 1) “先循环、后判断”结构 相当于高级语言的“直到型”循环 2) “先判断、后循环”结构 相当于高级语言的“当型循环”,可实现0次循环。 ;循 环 条件成立?;3.循环程序设计 编写循环程序的关键在于循环的控制。 循环次数已知:可用LOOP指令,CX计数。 如教材p154。 循环次数和ZF标志:可用LOOPZ、LOOPNZ指令。 例如7.6 循环次数未知:通常要采用各类条件转移指令实现循环控制。如字符串以0结尾;字符串以$结尾。 例如7.7;循环程序例题分析: 例7

文档评论(0)

dmdt5055 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档