顺序循环分支程序_第1页
顺序循环分支程序_第2页
顺序循环分支程序_第3页
顺序循环分支程序_第4页
顺序循环分支程序_第5页
已阅读5页,还剩16页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、第三章第三章 汇编语言程序设计汇编语言程序设计简单结构程序设计简单结构程序设计分支结构程序设计分支结构程序设计循环结构程序设计循环结构程序设计查表程序查表程序子程序子程序3.1 3.1 基本结构程序设计基本结构程序设计简单程序简单程序分支程序分支程序循环程序循环程序主要内容:主要内容: 用汇编语言进行程序设计的过程和用高级语言用汇编语言进行程序设计的过程和用高级语言进行程序设计的过程很相似。对于比较复杂的问题进行程序设计的过程很相似。对于比较复杂的问题可以先根据题目的要求作出流程图,然后再根据流可以先根据题目的要求作出流程图,然后再根据流程图来编写程序。程图来编写程序。 这一章中将介绍一些汇编

2、语言设计的实例及一这一章中将介绍一些汇编语言设计的实例及一些程序设计的方法。些程序设计的方法。一、简单程序一、简单程序 简单程序是指一种无分支的直接程序,即从第简单程序是指一种无分支的直接程序,即从第一条指令开始依次执行每一条指令,直到最后一条一条指令开始依次执行每一条指令,直到最后一条指令程序就算执行完毕。指令程序就算执行完毕。例例1 1:编程实现用:编程实现用80518051的的P1P1口控制口控制8 8个共阴极发光二个共阴极发光二极管全部点亮。极管全部点亮。程序段:程序段:ORG 0000HORG 0000HMAIN:MOV A,#0FFHMAIN:MOV A,#0FFHMOV P1,A

3、MOV P1,ASJMP $SJMP $ENDEND例例2 2:1616位二进制数的求补程序。(设一个位二进制数的求补程序。(设一个1616位二位二进制负数存放于进制负数存放于R1R0R1R0中,求补后的结果放于中,求补后的结果放于R3R2R3R2中)。中)。说明:一个二进制负数的求补可以归纳为说明:一个二进制负数的求补可以归纳为“求反加求反加1”1”的过程。的过程。 求反只需将符号位即最高位保持不变其余位按求反只需将符号位即最高位保持不变其余位按位求反即可。而加位求反即可。而加1 1只需将低只需将低8 8位加位加1 1,高,高8 8位加上低位加上低位的进位即可。位的进位即可。 程序段:程序段

4、:ORG 0000HORG 0000HCLR CCLR CMOV A,R0MOV A,R0CPL ACPL AADD A,#1ADD A,#1MOV R2,AMOV R2,AMOV A,R1MOV A,R1XRL A,#7FHXRL A,#7FHADDC A,#0ADDC A,#0MOV R3,AMOV R3,ASJMP $SJMP $ENDEND二、分支程序二、分支程序 分支程序也就是条件分支程序,即根据不同的分支程序也就是条件分支程序,即根据不同的条件执行不同的程序段。条件执行不同的程序段。例例3 3:设变量:设变量X X存放于内部存放于内部RAM30HRAM30H单元,函数值单元,函数值

5、Y Y存存放在内部放在内部RAM31HRAM31H单元,按下式要求给单元,按下式要求给Y Y赋值。赋值。Y=Y=1,X01,X00,X=00,X=0-1,X0-1,X0分析:分析: 不能使用不能使用CJNECJNE指令,因为该指令只能比较无符号指令,因为该指令只能比较无符号数。数。 题目中将题目中将X X看为了有符号数,可以根据它的符号看为了有符号数,可以根据它的符号位来决定其正负。位来决定其正负。源程序:源程序:ORG 0000HORG 0000HMAIN:MOV A,30HMAIN:MOV A,30HJZ COMPJZ COMPJNB ACC.7,POSIJNB ACC.7,POSIMOV

6、 A,#-1MOV A,#-1SJMP COMPSJMP COMPPOSI:MOV A,#1POSI:MOV A,#1COMP:MOV 31H,ACOMP:MOV 31H,AENDEND程序流程图:程序流程图:三、循环程序三、循环程序 循环程序也是一种程序的组织形式。在程序执循环程序也是一种程序的组织形式。在程序执行时,往往同样的一组操作需要重复许多次,当然行时,往往同样的一组操作需要重复许多次,当然可以重复使用同样的指令来完成,但若使用循环程可以重复使用同样的指令来完成,但若使用循环程序,重复执行同一条指令许多次来完成重复操作,序,重复执行同一条指令许多次来完成重复操作,就大大简化了程序。就

7、大大简化了程序。 例如:要做例如:要做1到到100的加法运算。的加法运算。在这里没有必要去写在这里没有必要去写100条加法指令,而可以只写条加法指令,而可以只写一条加法指令并使之执行一条加法指令并使之执行100次,每次执行时操作次,每次执行时操作数也作相应的变化,同样能完成原来规定的操作。数也作相应的变化,同样能完成原来规定的操作。循环程序一般由四部分组成:循环程序一般由四部分组成: 1.置循环初值。即确定循环开始时的状态,比如置循环初值。即确定循环开始时的状态,比如使工作单元清使工作单元清0,计数器置初值等。,计数器置初值等。 2.循环体部分。即要求重复执行的部分。这部分循环体部分。即要求重

8、复执行的部分。这部分程序应特别注意,因为它要重复执行许多次(如程序应特别注意,因为它要重复执行许多次(如100次),因此,若能少写一条指令,实际上就是次),因此,若能少写一条指令,实际上就是少执行少执行100条指令。反之亦然。条指令。反之亦然。 3.循环修改部分。循环程序必须在一定的条件下结循环修改部分。循环程序必须在一定的条件下结束,否则就要形成死循环。因此,每循环一次就要注束,否则就要形成死循环。因此,每循环一次就要注意是否需要修改达到循环结束的条件,若需要修改意是否需要修改达到循环结束的条件,若需要修改时,一定不要忘记,以便在一定情况下能结束循环。时,一定不要忘记,以便在一定情况下能结束

9、循环。 4.循环控制部分。根据循环结束条件,判断是否结循环控制部分。根据循环结束条件,判断是否结束循环。束循环。 实际设计时这四部分缺一不可。编写循环程序时实际设计时这四部分缺一不可。编写循环程序时这四部分可以有两种组织形式,如下图所示。这四部分可以有两种组织形式,如下图所示。 第一种形式:第一种形式:第二种形式:第二种形式:例例5:5:在内部在内部RAMRAM中,从中,从BLOCKBLOCK单元开始存放一组无单元开始存放一组无符号数,一般称为一个数据块。数据块长度放在符号数,一般称为一个数据块。数据块长度放在LENLEN单元,编写一求和程序,将和存入单元,编写一求和程序,将和存入SUMSUM

10、单元,设和不单元,设和不超过超过8 8位二进制数。位二进制数。( (数据大于数据大于1 1个小于个小于256256个个) )说明:在实际调试程序时,可以将说明:在实际调试程序时,可以将BLOCKBLOCK单元单元,LEN,LEN单单元和元和SUMSUM单元分别定义为具体的内部单元分别定义为具体的内部RAMRAM单元地址。单元地址。LEN DATA 20HLEN DATA 20HSUM DATA 21HSUM DATA 21HBLOCK DATA 22HBLOCK DATA 22HCLR A CLR A ;清累加器;清累加器MOV R2,LEN MOV R2,LEN ;数据块长度送;数据块长度送

11、R2R2MOV R1,#BLOCK MOV R1,#BLOCK ;数据块首地址送;数据块首地址送R1R1LOOP:ADD A,LOOP:ADD A,R1 R1 ;循环做加法;循环做加法INC R1 INC R1 ;修改地址指针;修改地址指针DJNZ R2,LOOP DJNZ R2,LOOP ;修改计数器并判断;修改计数器并判断MOV SUM,A MOV SUM,A ;存和;存和SJMP $SJMP $源程序:源程序:例例6:6: 多字节加法程序。有多字节加法程序。有1010组三字节的被加数和组三字节的被加数和加数,分别存在两个数据块中,首地址分别存于寄加数,分别存在两个数据块中,首地址分别存于

12、寄存器存器R0R0和和R1R1中,求这中,求这1010组数的组数的1010组和,各组的和仍组和,各组的和仍送回以送回以R0R0为指针的单元。为指针的单元。( (设两个三字节数的和仍设两个三字节数的和仍为三字节为三字节) )说明:这个问题要用双重循环程序来完成。因为多说明:这个问题要用双重循环程序来完成。因为多字节加法本身就需要用循环来完成,而字节加法本身就需要用循环来完成,而1010组多字节组多字节数的求和又需通过数的求和又需通过1010次循环来计算,这样就出现了次循环来计算,这样就出现了循环嵌套循环嵌套的情况。的情况。 由于是多字节相加,所以相加时要用由于是多字节相加,所以相加时要用ADDCADDC指指令。令。MOV R3,#10 MOV R3,#10 ;R3R3存几组数相加存几组数相加LOOP:MOV R2,#3 LOOP:MOV R2,#3 ;R2R2存字节数存字节数CLR C CLR C ;清;清CYCY位准备相加位准备相加LOOP1:MOV A,LOOP1:MOV A,R0 R0 ;取被加数;取被加数ADDC A,ADDC A,R1 R1 ;加一个字节;加一个字节MOV MOV R0R0,A

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论