- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
从程序看出,汇编语言源程序通常有几个段构成,每个段以 SEGMENT语句开始,以ENDS语句结束,并分别有一个段名。第一段是数据段,段名DATA,用来定义变量,存放原始数据和运算结果。第二段为代码段,段名为CODE,用来安排执行代码,是用户编程实现各项功能的主要部分。 整个源程序必须用END语句结束,它通知汇编程序停止汇编,END后面的标号START指明该程序执行的启动地址。源程序中各段的名字可以任选,段的数目可以根据需要确定.如果用到堆栈段和附加段,在段的定义的时候也要定义出来。 DATA SEGMENT ;定义数据段 DATA ENDS ;数据段结束 ESEG SEGMENT ;定义附加段 ESEG ENDS ;附加段结束 CODE SEGMENT ;定义代码段 ASSUME CS:CODE, DS:DATA,SS:STack,ES:ESEG ;段的 分配 START: MOV AX,DATA ;指令性语句开始(我们第二章学习编写的程序) MOV DS,AX MOV AX,ESEG MOV ES,AX MOV AX,STack MOV SS,AX ;编写第二章学习的主程序 时间:2010—10月18日(第八周周一) 1、掌握汇编语言程序的设计步骤 。 2、掌握汇编语言程序设计分类。 §5.2汇编语言程序设计 一、汇编语言程序的设计步骤 1) 建立数学模型 ??? 这是能否编制出高质量程序的关键,因此首先应该对求解的问题进行仔细的分析、正确理解题意,给问题的处理过程以精确、清晰的描述。 2) 确定数据结构与算法 ??对问题有了充分理解和精确描述后,根据本题要求选择合理的数据结构及恰当的算法。 3) 绘制流程图及编制程序 ??? 在合理的算法及确定的数据结构基础上,把求解问题的先后次序用流程图直观地描述出来。这一点对初学者特别重要,这样做可以减少出错的概率。 ?? 根据流程图中每框的要求,合理选择适当的指令来实现其功能,从而编出相应的程序。 4) 调试 ??? 任何程序必须经过调试才能检查出你的设计思想是否正确以及你的程序是否符合你的设计要求。调试分为静态和动态调试,前者是检查编制的程序是否与确定的算法相符合,能否完成预定的任务;后者即上机调试,主要对程序进行测试、跟踪调试,不断发现并纠正错误。在调试程序过程中应该善于利用机器提供的调试工具(如 DEBUG)来进行工作。 二、 程序流程图 ??? 程序流程图又称作框图,它是一种由逻辑框,流程线及文字说明等组成的,用来描述计算过程的示意图,它可以简明扼要地表达计算机完成某个给定问题的确定算法的逻辑操作过程。流程图一般由处理框、判断框、流程线、连接框和起止框等构成。 1) 处理框 ??? 处理框又称执行框。它使用矩形框来表示一种处理功能的模块。它有一个入口和一个出口,其框内可以写入简要的说明。它可以用一条或一组指令来实现其功能。 2) 判断框 ??? 判断框常用菱形框来表示,它用来指明判定点。框内指明判断条件。它有一个入口和两个以上的出口,在各出口处要写明条件,成立时标明“是”或“Y”,不成立时标明“否”或“N”来表示。 (一)、顺序结构 例:自然数0~15的平方表,存在内存TABLE开始的连续16个单元中,现XAD单元存有任意一自然数(0? X ? 15),查表求X的平方,存入YAD单元中。 data segment table db 0,1,4,9,16,25,36,49,56,81 db 100,121,144,169,196,225 xad db 3 yad db ? data ends 例、从内存ADR单元开始,连续存放出1000个学生的某门课成绩. 统计90~100, 70~89, 60~69, 60以下各段人数. 解: 设 CX: 计数器, SI: 地址指针. 定义: S5, S6 ,S7 ,S9 单元 存放各分数段的人数. AL: 待查分数. DATA SEGMENT ORG 1000H DAT1 DB -1,2,3,-9… COUNT DW N MN DB ? DATA ENDS CODE SEGMENT ASSUME CS:CODE,DS:DAT
文档评论(0)