89C51汇编语言程序的设计与调试_第1页
89C51汇编语言程序的设计与调试_第2页
89C51汇编语言程序的设计与调试_第3页
89C51汇编语言程序的设计与调试_第4页
89C51汇编语言程序的设计与调试_第5页
已阅读5页,还剩82页未读 继续免费阅读

下载本文档

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

文档简介

1、第第4 4章章 89C5189C51汇编语言程序的设计与调试汇编语言程序的设计与调试 汇编语言是面向机器硬件的语言汇编语言是面向机器硬件的语言,要求程序设计者对,要求程序设计者对89C5189C51单片单片机具有很好的机具有很好的“软、硬结合软、硬结合”的功底。的功底。 介绍介绍程序设计的基本知识程序设计的基本知识及如何及如何使用汇编语言来进行基本的程使用汇编语言来进行基本的程序设计。序设计。4.1 4.1 汇编语言程序设计概述汇编语言程序设计概述程序是若干指令的有序集合,单片机的运行就是执行这一指令程序是若干指令的有序集合,单片机的运行就是执行这一指令序列的过程,编写这一指令序列的过程称为序

2、列的过程,编写这一指令序列的过程称为程序设计程序设计。 4.1.1 4.1.1 机器语言、汇编语言和高级语言机器语言、汇编语言和高级语言用于程序设计的用于程序设计的语言基本上分为语言基本上分为3 3种:机器语言、汇编语言和高种:机器语言、汇编语言和高级语言级语言。 1.1.机器语言机器语言 二进制代码表示的指令、数字和符号简称为机器语言不易懂,二进制代码表示的指令、数字和符号简称为机器语言不易懂,难记忆,易出错。难记忆,易出错。2 2汇编语言汇编语言 英文助记符表示的指令称为英文助记符表示的指令称为符号语言符号语言或或汇编语言汇编语言将汇编语言程序转换成为二进制代码表示的机器语言程序称将汇编语

3、言程序转换成为二进制代码表示的机器语言程序称为为汇编程序汇编程序经汇编程序经汇编程序“汇编(翻译)汇编(翻译)”得到的机器语言程序称为得到的机器语言程序称为目标目标程序程序,原来的汇编语言程序称为,原来的汇编语言程序称为源程序源程序。汇编语言特点汇编语言特点:面向机器的语言,程序设计员须对面向机器的语言,程序设计员须对89C5189C51的硬件有相当深的硬件有相当深入的了解。入的了解。助记符指令和机器指令一一对应,用汇编语言编写的助记符指令和机器指令一一对应,用汇编语言编写的程序程序效率高效率高,占用,占用存储空间小存储空间小,运行,运行速度快速度快,用汇编语言能编,用汇编语言能编写出最优化的

4、程序。写出最优化的程序。能能直接管理和控制硬件设备直接管理和控制硬件设备(功能部件),它能处理中断,(功能部件),它能处理中断,也能直接访问存储器及也能直接访问存储器及I/OI/O接口电路。接口电路。 汇编语言和机器语言都脱离不开具体机器的硬件,均是面向汇编语言和机器语言都脱离不开具体机器的硬件,均是面向“机器机器”的语言,缺乏通用性。的语言,缺乏通用性。3 3高级语言高级语言不受具体机器的限制不受具体机器的限制, ,使用了许多数学公式和数学计算上的习惯使用了许多数学公式和数学计算上的习惯用语,用语,非常擅长于科学计算。非常擅长于科学计算。常用的如常用的如BASICBASIC、FORTRANF

5、ORTRAN以及以及C C语言等。语言等。高级语言高级语言优点优点:通用性强,直观、易懂、易学,可读性好。:通用性强,直观、易懂、易学,可读性好。计算机不能直接识别和执行高级语言,需要将其计算机不能直接识别和执行高级语言,需要将其 “ “翻译翻译”成机成机器语言才能识别和执行,进行器语言才能识别和执行,进行“翻译翻译”的专用程序称为的专用程序称为编译编译程序程序。 使用使用C C语言(语言(C51C51)、)、PL/MPL/M语言来进行语言来进行89C5189C51的应用程序设计。的应用程序设计。 对于程序的空间和时间要求很高的场合,汇编语言仍是必不对于程序的空间和时间要求很高的场合,汇编语言

6、仍是必不可缺的。可缺的。C C语言和汇编语言混合编程语言和汇编语言混合编程 在很多需要在很多需要直接控制硬件直接控制硬件的应用场合,更是非用汇编语言不的应用场合,更是非用汇编语言不可可. . 使用使用汇编语言编程汇编语言编程,是单片机程序设计的,是单片机程序设计的基本功之一基本功之一4.1.2 4.1.2 汇编语言语句的种类和格式汇编语言语句的种类和格式两种基本类型:两种基本类型:指令语句指令语句和和伪指令语句伪指令语句(1 1)指令语句)指令语句已在第已在第3 3章介绍章介绍每一条指令语句在汇编时都产生一个指令代码每一条指令语句在汇编时都产生一个指令代码机器代码机器代码(2 2)伪指令语句)

7、伪指令语句 是为汇编服务的。在汇编时是为汇编服务的。在汇编时没有机器代码与之对应。没有机器代码与之对应。 89C5189C51的汇编语言的的汇编语言的四分段格式四分段格式如下:如下: ( (标号字段标号字段):):操作码操作码 ( (操作数操作数1(,1(,操作数操作数2(2(操作数操作数3);3);注释字段注释字段规则:规则:(1 1)标号字段和操作字码段之间要有冒号)标号字段和操作字码段之间要有冒号“:”相隔;相隔;(2 2)操作码字段和操作数字段间的分界符是空格;)操作码字段和操作数字段间的分界符是空格;(3 3)操作数之间用逗号相隔;)操作数之间用逗号相隔; (4 4)操作数字段和注释

8、字段之间的分界符用分号)操作数字段和注释字段之间的分界符用分号“;”相隔。相隔。操作码字段为必选项,其余各段为任选项。操作码字段为必选项,其余各段为任选项。例例4-14-1 下面是一段汇编语言程序的四分段书写格式下面是一段汇编语言程序的四分段书写格式 标号字段标号字段 操作码字段操作码字段 操作数字段操作数字段 注释字段注释字段 STARTSTART:MOV AMOV A,#00H #00H ;0A0A MOV R1 MOV R1,#10 #10 ;10R110R1 MOV R2MOV R2,#00000011B #00000011B ;3R23R2LOOPLOOP:ADD AADD A,R2

9、 R2 ;(;(A A)+ +(R2R2)AADJNZ R1DJNZ R1,LOOPLOOP;R1R1内容减内容减1 1不为零,则循环不为零,则循环 NOPNOP HERE HERE: SJMP HERESJMP HERE基本语法规则:基本语法规则:1 1标号字段标号字段是语句所在地址的标志符号是语句所在地址的标志符号 (1 1)标号后边必须跟以冒号)标号后边必须跟以冒号“:” ” (2 2)由)由1-81-8个个ASCIIASCII字符组成字符组成(3 3)同一标号在一个程序中只能定义一次)同一标号在一个程序中只能定义一次 (4 4)不能使用汇编语言已经定义的符号作为标号)不能使用汇编语言已

10、经定义的符号作为标号 2 2操作码字段操作码字段 是汇编语言指令中是汇编语言指令中唯一不能空缺唯一不能空缺的部分。汇编程序就是的部分。汇编程序就是根据这根据这一字段来生成机器代码一字段来生成机器代码的。的。3 3操作数字段操作数字段 通常有单操作数、双操作数、三通常有单操作数、双操作数、三操作数操作数和无操作数和无操作数4 4种情况。种情况。(1 1)十六进制、二进制和十进制形式的操作数表示)十六进制、二进制和十进制形式的操作数表示采用十六采用十六进制形式来表示进制形式来表示 ,某些特殊场合才采用二进制或十进制的,某些特殊场合才采用二进制或十进制的表示形式表示形式 。十六进制,后缀十六进制,后

11、缀“H”H” 。二进制,后缀二进制,后缀“B”B” 。十进制,后缀十进制,后缀“D”D”,也可省略也可省略。若十六进制的若十六进制的操作数以字符操作数以字符A A- -F F中的某个开头时,则需在它中的某个开头时,则需在它前前面加一个面加一个 “ “0”0”,以便在汇编时把它和字符,以便在汇编时把它和字符A AF F区别开来。区别开来。(2 2)工作寄存器和特殊功能寄存器的表示)工作寄存器和特殊功能寄存器的表示采用工作寄存器和特殊功能寄存器的代号来表示,也可用其地采用工作寄存器和特殊功能寄存器的代号来表示,也可用其地址来表示。址来表示。 例如,例如,累加器可用累加器可用A A(或(或AccAc

12、c)表示。也可用表示。也可用0E0H0E0H来表示,来表示,0E0H0E0H为累加器为累加器A A的直接(的直接(directdirect)地址。)地址。(3 3)美元符号)美元符号$ $的使用的使用用于表示该转移指令操作码所在的地址。例如,如下指令:用于表示该转移指令操作码所在的地址。例如,如下指令: JNB F0JNB F0, $ $与如下指令是等价的:与如下指令是等价的: HEREHERE:JNB F0JNB F0,HEREHERE 再如:再如:HEREHERE:SJMP HERESJMP HERE可写为:可写为: SJMP $SJMP $4 4注释字段注释字段 必须以分号必须以分号“;

13、”开头,换行书写,但必须注意也要以分号开头,换行书写,但必须注意也要以分号“;”开头。开头。 汇编时,注释字段不会产生机器代码。汇编时,注释字段不会产生机器代码。4.1.3 4.1.3 伪指令伪指令在在89C51 89C51 汇编语言源程序中应有向汇编程序发出的指示信息,汇编语言源程序中应有向汇编程序发出的指示信息,告诉它告诉它如何完成汇编工作如何完成汇编工作,这是通过使用伪指令来实现的。,这是通过使用伪指令来实现的。也称为汇编程序控制命令。只有在汇编前的源程序中才有伪也称为汇编程序控制命令。只有在汇编前的源程序中才有伪指令。经过汇编得到目标程序(机器代码)指令。经过汇编得到目标程序(机器代码

14、)后,伪指令已无存在的必要,所以后,伪指令已无存在的必要,所以“伪伪”体现在汇编时,体现在汇编时,伪指伪指令没有相应的机器代码产生令没有相应的机器代码产生。常用的伪指令常用的伪指令: 1.ORG1.ORG(ORiGinORiGin)汇编起始地址命令)汇编起始地址命令在汇编语言源程序的开始,通常都用一条在汇编语言源程序的开始,通常都用一条ORGORG伪指令来实现规定伪指令来实现规定程序的起始地址。如不用程序的起始地址。如不用ORGORG规定,则汇编得到的目标程序将规定,则汇编得到的目标程序将从从0000H0000H开始。例如:开始。例如: ORG 0030HORG 0030HSTARTSTART

15、:MOV SP,#60HMOV SP,#60H规定标号规定标号STARTSTART代表地址为代表地址为0030H0030H开始。开始。在一个源程序中,在一个源程序中,可可多次多次使用使用ORGORG指令指令,来规定不同的程序,来规定不同的程序段的起始地址。但是,段的起始地址。但是,地址必须由小到大排列,地址不能地址必须由小到大排列,地址不能交叉、重叠交叉、重叠。例如:。例如:ORG 0000HORG 0000H ORG 0003HORG 0003H ORG 0030HORG 0030H2. END(END of assembly)2. END(END of assembly)汇编终止命令汇编终

16、止命令汇编语言源程序的结束标志,用于终止源程序的汇编工作。汇编语言源程序的结束标志,用于终止源程序的汇编工作。在整个源程序中只能有一条在整个源程序中只能有一条ENDEND命令,且位于程序的最后。命令,且位于程序的最后。3 3DBDB(Define ByteDefine Byte)定义字节命令)定义字节命令在程序存储器的连续单元中定义字节数据。在程序存储器的连续单元中定义字节数据。 ORG 2000HORG 2000HDB 30HDB 30H,40H40H,2424,“C”C”,“B”B”汇编后:汇编后:(2000H2000H)=30H=30H(2001H2001H)=40H=40H(2002H

17、2002H)=18H=18H(1010进制数进制数2424)(2003H2003H)=43H=43H(字符(字符“C”C”的的ASCIIASCII码)码)(2004H2004H)=42H=42H(字符(字符“B”B”的的ASCIIASCII码)码)DB DB 功能是功能是从指定单元开始定义(存储)若干个字节,从指定单元开始定义(存储)若干个字节,1010进制数自然转换成进制数自然转换成1616进制数,字母按进制数,字母按ASCIIASCII码存储。码存储。4 4DWDW(Define WordDefine Word)定义数据字命令)定义数据字命令从指定的地址开始,在程序存储器的连续单元中定义从

18、指定的地址开始,在程序存储器的连续单元中定义1616位的数据字。例如:位的数据字。例如:ORG 2000HORG 2000H DW 1246H DW 1246H,7BH7BH,1010汇编后:汇编后:(2000H2000H)= =12H12H;第;第1 1个字个字(2001H2001H)= =46H46H (2002H2002H)=00H=00H;第;第2 2个字个字(2003H2003H)=7BH=7BH(2004H2004H)=00H=00H;第;第3 3个字(个字(2005H2005H)=0AH=0AH(2005H2005H)=0AH =0AH 5 5EQUEQU(EQUateEQUat

19、e)赋值命令)赋值命令用于用于给给符号符号赋值赋值。赋值以后,其符号值在整个程序有效。该符。赋值以后,其符号值在整个程序有效。该符号既可以做地址单元,也可以做立即数用号既可以做地址单元,也可以做立即数用例如例如:TEST EQU 20HTEST EQU 20H ORG 0030H ORG 0030HMOV TEST,AMOV TEST,A MOV A,#TEST MOV A,#TEST SETB TEST.3 SETB TEST.3 JNB TEST,LL JNB TEST,LL6 6BIT BIT 位赋值命令位赋值命令 例如:例如: LED1 BIT P1.0LED1 BIT P1.0 KE

20、Y3 BIT P3.2 KEY3 BIT P3.2 FLAG BIT 20H.5 FLAG BIT 20H.5 ORG 0000H ORG 0000H CPL LED1 CPL LED1 JB KEY3, NEXT JB KEY3, NEXT CLR FLAG CLR FLAG4.1.4 4.1.4 汇编语言程序设计步骤汇编语言程序设计步骤(1 1)分析问题,确定算法)分析问题,确定算法(2 2)根据算法,画出程序框图)根据算法,画出程序框图(3 3)分配内存工作区及有关端口地址)分配内存工作区及有关端口地址(4 4)编写程序)编写程序, ,养成在程序的养成在程序的适当位置上加上注释适当位置上

21、加上注释的好习惯。的好习惯。(5 5)上机调试)上机调试编写完毕的程序,必须编写完毕的程序,必须“汇编汇编”成机器代码,才能调试和运成机器代码,才能调试和运行,调试与硬件有关程序还要借助于仿真开发工具并与硬行,调试与硬件有关程序还要借助于仿真开发工具并与硬件连接。件连接。4.2 4.2 汇编语言源程序的汇编汇编语言源程序的汇编汇编语言源程序汇编语言源程序 “ “翻译翻译”成机器代码(指令代码)的过程称成机器代码(指令代码)的过程称为为“汇编汇编”。汇编后的机器代码是在另一台计算机(这里是单片机)上运行。汇编后的机器代码是在另一台计算机(这里是单片机)上运行。 89C5189C51单片机的应用程

22、序的完成,应经过三个步骤;单片机的应用程序的完成,应经过三个步骤;(1 1)在微计算机上,运行编辑程序进行源程序的)在微计算机上,运行编辑程序进行源程序的输入和编辑输入和编辑; (2 2)对源程序进行)对源程序进行汇编汇编得到机器代码;得到机器代码;(3 3)通过微计算机的串行口(或并行口)把)通过微计算机的串行口(或并行口)把机器代码传送机器代码传送到到用用户样机(或在线仿真器户样机(或在线仿真器)进行程序的调试和运行。)进行程序的调试和运行。第一步,第一步,只需在微计算机上使用通用的编辑软件即可完成。只需在微计算机上使用通用的编辑软件即可完成。第二步第二步,汇编所用的汇编程序可在购买单片机

23、的仿真开发工具,汇编所用的汇编程序可在购买单片机的仿真开发工具时,由厂商提供。时,由厂商提供。第三步第三步,要借助于单片机仿真开发工具进行。,要借助于单片机仿真开发工具进行。反汇编反汇编分析现成产品的程序,要将二进制的机器代码语言分析现成产品的程序,要将二进制的机器代码语言程序翻译成汇编语言源程序。程序翻译成汇编语言源程序。4.3 4.3 汇编语言实用程序设计汇编语言实用程序设计 4.3.1 4.3.1 汇编语言程序的基本结构汇编语言程序的基本结构常采用以下几种基本结构:常采用以下几种基本结构: 顺序结构顺序结构、分支结构分支结构和和循环结构循环结构,再加上广泛使用的,再加上广泛使用的子程序子

24、程序和和中断服务子程序中断服务子程序。 1 1顺序结构顺序结构 2 2分支结构分支结构 程序中含有转移指令,程序中含有转移指令, 无条件分支,有条件分支无条件分支,有条件分支。 有条件分支又分为:有条件分支又分为:单分支单分支结构和结构和多分支多分支结构。结构。 3 3循环结构循环结构 4 4子程序子程序 5 5中断服务子程序中断服务子程序4.3.2 4.3.2 子程序的设计子程序的设计1. 1. 子程序设计原则和应注意的问题子程序设计原则和应注意的问题 一种能完成某一特定任务的程序段一种能完成某一特定任务的程序段。该子程序要为所有调用。该子程序要为所有调用程序共享。因此,子程序在结构上应具有

25、独立性和通用性。程序共享。因此,子程序在结构上应具有独立性和通用性。编写子程序时应注意以下问题:编写子程序时应注意以下问题: 1 1子程序的第一条指令的地址称为子程序的入口地址。该指子程序的第一条指令的地址称为子程序的入口地址。该指令前令前必须有标号必须有标号。 2 2主程序调用子程序主程序调用子程序 两条子程序调用指令:两条子程序调用指令: (1 1)绝对调用指令:)绝对调用指令:ACALL addr11ACALL addr11 (2 2)长调用指令:)长调用指令:LCALL addr16;LCALL addr16;3 3注意设置堆栈指针和现场保护注意设置堆栈指针和现场保护4 4最后一条指令

26、必须是最后一条指令必须是RETRET指令指令5 5子程序可以嵌套,即子程序可以嵌套,即子程序可以调用子程序子程序可以调用子程序6 6在子程序调用时,还要注意在子程序调用时,还要注意参数传递参数传递的问题的问题 2. 2. 子程序的基本结构子程序的基本结构 MAINMAIN: ;MAINMAIN为主程序或调用程序标号为主程序或调用程序标号 LCALL SUB LCALL SUB ;调用子程序;调用子程序SUBSUB SUBSUB:PUSH PSWPUSH PSW;现场保护;现场保护 PUSH ACCPUSH ACC; 子程序处理程序段子程序处理程序段POP ACCPOP ACC;现场恢复;现场恢

27、复POP PSWPOP PSW; RETRET;最后一条指令必须为;最后一条指令必须为RETRET例例4-34-3 单字节有符号数的加减法子程序(自己阅读)单字节有符号数的加减法子程序(自己阅读) 本例中参数传递是通过累加器本例中参数传递是通过累加器A A完成的,主程序将被转换的数送完成的,主程序将被转换的数送到到A A中,子程序将中,子程序将A A中的有符号数求补后存于中的有符号数求补后存于A A中,主程序再中,主程序再将结果放回原来的单元。将结果放回原来的单元。例例4-44-4 4 4位位BCDBCD码的减法程序(自己阅读)码的减法程序(自己阅读)主程序通过地址寄存器主程序通过地址寄存器R

28、0R0和和R1R1将参加运算的将参加运算的BCDBCD码的地码的地址传递给子程序,子程序则通过累加器将差传递给址传递给子程序,子程序则通过累加器将差传递给主程序。主程序。4.3.3 4.3.3 查表程序设计查表程序设计 数据补偿、修正、计算、转换等各种功能,具有程序数据补偿、修正、计算、转换等各种功能,具有程序简单、执行速度快等优点。简单、执行速度快等优点。查表就是根据自变量查表就是根据自变量x x, ,在表格中寻找在表格中寻找y y, ,使使y=f(x)y=f(x)。两条查表指令如下:两条查表指令如下: MOVC MOVCA A,A+DPTRA+DPTR MOVC MOVCA A,A+PCA

29、+PCMOVC AMOVC A,A+DPTRA+DPTR完成把完成把A A中的内容作为一个无符号数与中的内容作为一个无符号数与DPTRDPTR中的内容相加,所得中的内容相加,所得结果为某一程序存储单元的地址,然后把该地址单元中的内结果为某一程序存储单元的地址,然后把该地址单元中的内容送到累加器容送到累加器A A中。中。MOVCMOVCA A,A+PCA+PC以以PCPC作为基址寄存器,作为基址寄存器,PCPC的内容和的内容和A A的内容作为无符号数,相加的内容作为无符号数,相加后所得的数作为某一程序存储器单元的地址,根据地址取后所得的数作为某一程序存储器单元的地址,根据地址取出程序存储器相应单

30、元中的内容送到累加器出程序存储器相应单元中的内容送到累加器A A中。中。指令执行完,指令执行完,PCPC的内容不发生变化,仍指向查表指令的下一条的内容不发生变化,仍指向查表指令的下一条指令。指令。优点优点: :预处理较少且不影响其它特殊功能寄存器的值,所以不预处理较少且不影响其它特殊功能寄存器的值,所以不必保护其它特殊功能寄存器的原先值必保护其它特殊功能寄存器的原先值缺点缺点: :在于该表格在于该表格只能存放在只能存放在这条指令的地址附近的这条指令的地址附近的00H00HFFHFFH之中。表格之中。表格所在的程序空间受到了限制。所在的程序空间受到了限制。例例4-44-4 子程序的功能为:根据累

31、加器子程序的功能为:根据累加器A A中的数中的数x x(0 09 9之间)之间)查查x x的平方表的平方表y y,根据,根据x x的值查出相应的平方的值查出相应的平方y y。x x和和y y均为均为单单字节数。字节数。 ADD AADD A,#1,#1 MOVC A,A+PCMOVC A,A+PC SJMP $ SJMP $;单字节指令单字节指令DB DB 00H,01H,04H,09H,10H 00H,01H,04H,09H,10HDBDB 19H,24H,31H,40H,51H 19H,24H,31H,40H,51H第第1 1条指令条指令 ADD AADD A,#1 #1 的作用的作用是加

32、上偏移量,可以根据是加上偏移量,可以根据A A的的内容查出内容查出X X对应的平方对应的平方 MOVC AMOVC A,A+DPTRA+DPTR 这条指令的应用范围较为广泛,一般情况下,这条指令的应用范围较为广泛,一般情况下,大多使用该指大多使用该指令令,使用该指令时不必计算偏移量,使用该指令的,使用该指令时不必计算偏移量,使用该指令的优点优点是表是表格可以设格可以设在在64K64K程序存储器空间内的任何地方程序存储器空间内的任何地方,而不像,而不像 MOVC MOVC A A,A+PCA+PC那样只设在那样只设在PCPC下面的下面的256256个单元中,使用较方便。个单元中,使用较方便。缺点

33、是占用了缺点是占用了DPLDPL和和DPHDPH 。 上面的程序可改成如下形式:上面的程序可改成如下形式: MOV DPTRMOV DPTR,#TAB1#TAB1 MOVC AMOVC A,A+DPTRA+DPTR SJMP $ SJMP $TAB1: TAB1: DBDB 00H 00H,01H01H,04H04H,09H09H,10H 10H DBDB 19H 19H,24H24H,31H31H,40H40H,51H51H例例4-54-5 在一个以在一个以89C5189C51为核心的为核心的温度控制器温度控制器中,温度中,温度传感器输出的电压与温度为非线性关系,传感器输传感器输出的电压与温

34、度为非线性关系,传感器输出的出的电压已由电压已由A/DA/D转换为转换为1010位二进制数位二进制数。根据测得的。根据测得的不同温度下的电压值数据构成一个表,表中放不同温度下的电压值数据构成一个表,表中放温度温度值值y y,x x为电压值为电压值数据数据。(双字节表格)。(双字节表格)设测得的电压值设测得的电压值x x放入放入R2R3R2R3中,根据电压值中,根据电压值x x,查找对应的温度查找对应的温度值值y y,仍放入仍放入R2R3R2R3中中。本例的。本例的x x和和y y均为均为双字节无符号数双字节无符号数。程。程序如下:序如下: LTB2LTB2:MOV DPTR,#TAB2MOV

35、DPTR,#TAB2 MOV A,R3 MOV A,R3 CLR C CLR C RLC A RLC A;A A* *2 2 MOV R3,A MOV R3,A XCH A,R2 XCH A,R2 RLC A RLC A XCH A,R2XCH A,R2 ADD A,DPL ADD A,DPL ;(;(R2R3R2R3)+ +(DPTRDPTR)(DPTRDPTR) MOV DPL,AMOV DPL,A MOV A,DPH MOV A,DPH ADDC A,R2 ADDC A,R2 MOV DPH,A MOV DPH,A CLR A CLR A MOVC A,A+DPTRMOVC A,A+DP

36、TR ;查第一字节;查第一字节 MOV R2,A MOV R2,A ;第一字节存入;第一字节存入R2R2中中 CLR ACLR A INC DPTR INC DPTR MOVC A,A+DPTRMOVC A,A+DPTR ;查第二字节;查第二字节 MOV R3,A MOV R3,A ;第二字节存入;第二字节存入R3R3中中 RETRET TAB2: TAB2: DW DW ;温度值表;温度值表例例4-64-6 设有一个设有一个巡回检测报警装置巡回检测报警装置,需对,需对1616路输入进行检测,路输入进行检测,每路有一最大允许值,为每路有一最大允许值,为双字节数双字节数。运行时,需根据测量运行时

37、,需根据测量的路数,找出每路的最大允许值。看输入值是否大于最大的路数,找出每路的最大允许值。看输入值是否大于最大允许值,如大于就报警。根据上述要求,编一个查表程序允许值,如大于就报警。根据上述要求,编一个查表程序。取路数为取路数为x(0-15),yx(0-15),y为最大允许值,放在表格中。设进入查表为最大允许值,放在表格中。设进入查表程序前,程序前,路数路数x x已放于已放于R2R2中中,查表后,查表后最大值最大值y y放于放于R3R3、R4R4中。中。本例中的本例中的x x为为单字节数单字节数,y y为为双字节数双字节数。查表程序如下:。查表程序如下: MOV A,R2MOV A,R2 A

38、DD A,R2 ADD A,R2 ;(R2)(R2)* *2(A)2(A) MOV R3,A MOV R3,A ;保存指针;保存指针 ADD A,#6 ADD A,#6 ;加偏移量;加偏移量MOVC A,A+PCMOVC A,A+PC ;查第一字节;查第一字节XCH A,R3XCH A,R3 ADD A,#3ADD A,#3 MOVC A,A+PCMOVC A,A+PC ;查第二字节;查第二字节 MOV R4,AMOV R4,ARETRET TAB3: TAB3: DWDW 1520 1520,37213721,4264542645,7580 7580 ;最大值表;最大值表 DWDW 3483

39、 3483,3265732657,883883,99439943 DW DW 10000 10000,4051140511,67586758,89318931 DWDW 4468 4468,58715871,1328413284,2780827808表格长度不能超过表格长度不能超过256256个字节,且表格只能存放于个字节,且表格只能存放于MOVC A,A+PCMOVC A,A+PC指令以下的指令以下的256256个单元中。个单元中。4.3.4 4.3.4 关键字查找程序设计关键字查找程序设计顺序检索和对分检索顺序检索和对分检索1. 1. 顺序检索顺序检索 从第从第1 1项开始逐项顺序查找,判

40、断所取数据是否与关键字相等。项开始逐项顺序查找,判断所取数据是否与关键字相等。例例4-74-7 从从5050个字节的无序表中查找一个关键字个字节的无序表中查找一个关键字XXHXXH。MOV 40HMOV 40H,# #XXXXH H ;关键字;关键字XXHXXH送送40H40H单元单元MOV R1MOV R1,#50#50 ;查找次数送;查找次数送R1R1MOV AMOV A,#14#14 ;修正值送;修正值送A AMOV DPTRMOV DPTR,#TAB4 #TAB4 ;表首地址送;表首地址送DPTRDPTRLOOPLOOP:PUSH ACCPUSH ACCMOVC AMOVC A, A+

41、PC A+PC;查表结果送;查表结果送A ACJNE ACJNE A,40H40H,LOOP1LOOP1;(40H40H)不等于关键字则)不等于关键字则;转;转LOOP1LOOP1MOV R2MOV R2,DPHDPH;已查到关键字,把该字已查到关键字,把该字 ;的地址送;的地址送R2R2,R3R3MOV R3MOV R3,DPL DPL ;DONEDONE:RETRETLOOP1LOOP1:POP POP ACCACC;修正值弹出;修正值弹出 INC AINC A;A+1AA+1A INC DPTRINC DPTR ;修改数据指针;修改数据指针DPTRDPTR DJNZ R1DJNZ R1,

42、LOOP LOOP ;R10R10,未查完,继续查找,未查完,继续查找MOV MOV R2R2,#00H#00H;R1=0R1=0,清,清“0” R2 0” R2 和和R3R3 MOV MOV R3R3,#00H#00H;表中;表中5050个数已查完个数已查完 AJMPAJMPDONEDONE;从子程序返回;从子程序返回TAB4TAB4:DBDB ,;5050个无序数据表个无序数据表 2. 2. 对分检索对分检索前提:前提:检索的检索的数据表已经排好序数据表已经排好序,如何进行数据的排序,将在,如何进行数据的排序,将在本节稍后介绍。本节稍后介绍。方法:方法:取数据取数据表中间位置表中间位置的数

43、与关键字进行比较,的数与关键字进行比较,如相等如相等,则,则查找到;查找到;如果所取的数如果所取的数大于大于关键字关键字,则下次对分检索的范,则下次对分检索的范围是从数据区起点到本次取数。围是从数据区起点到本次取数。如果取数小于关键字如果取数小于关键字,则,则下次对分检索的范围是从本次取数数据区起点到数据区终下次对分检索的范围是从本次取数数据区起点到数据区终点。依此类推,逐渐缩小检索范围,减少次数,大大点。依此类推,逐渐缩小检索范围,减少次数,大大提高提高查找速度查找速度。4.3.5 4.3.5 数据极值查找程序设计数据极值查找程序设计在指定的数据区中在指定的数据区中找出最大值(或最小值)。找

44、出最大值(或最小值)。进行数值大小的比较,从这批数据中找出最大值(或最小值)进行数值大小的比较,从这批数据中找出最大值(或最小值)并存于某一单元中。并存于某一单元中。例例4-84-8 片内片内RAMRAM中存放一批数据,查找出最大值并存放于首地中存放一批数据,查找出最大值并存放于首地址中。设址中。设R0R0中存首地址,中存首地址,R2R2中存放字节数,程序框图如中存放字节数,程序框图如图图4-4-1 1所示。所示。程序如下:程序如下: MOV R2MOV R2,n n;n n为要比较的数据字节数为要比较的数据字节数MOV AMOV A,R0R0;存首地址指针;存首地址指针图图4-14-1MOV

45、MOVR1R1,A ADEC R2DEC R2; MOV AMOV A,R1 R1 LOOP:LOOP:MOVMOVR3R3, A A DECDECR1R1 CLRCLRC C SUBBSUBBA A,R1R1;两个数比较;两个数比较 JNCJNCLOOP1LOOP1;C=0C=0,A A中的数大,跳中的数大,跳LOOP1LOOP1 MOVMOVA A,R1R1;C=1C=1,则大数送,则大数送A A SJMPSJMPLOOP2LOOP2LOOP1:LOOP1:MOVMOVA A,R3 R3 LOOP2:LOOP2:DJNZDJNZR2, LOOPR2, LOOP;是否比较结束?;是否比较结束

46、? MOVMOVR0R0, A A;存最大数;存最大数 RET RET 4.3.6 4.3.6 数据排序程序设计数据排序程序设计升序排,降序排升序排,降序排。仅介绍无符号数据。仅介绍无符号数据升序排升序排。冒泡法:冒泡法:相邻数互换的排序方法,类似水中气泡上浮相邻数互换的排序方法,类似水中气泡上浮 。排序排序时时从前向后进行相邻两个数的比较,次序与要求的顺序不符从前向后进行相邻两个数的比较,次序与要求的顺序不符时,就将两个数互换;顺序符合要求不互换。时,就将两个数互换;顺序符合要求不互换。 假设有假设有7 7个原始数据的排列顺序为:个原始数据的排列顺序为:6 6、4 4、1 1、2 2、5 5

47、、7 7、3 3。第一次冒泡的过程是第一次冒泡的过程是:6 6、4 4、1 1、2 2、5 5、7 7、3 3 ;原始数据的排列;原始数据的排列4 4、6 6、1 1、2 2、5 5、7 7、3 3 ;逆序,互换;逆序,互换4 4、1 1、6 6、2 2、5 5、7 7、3 3 ;逆序,互换;逆序,互换 4 4、1 1、2 2、6 6、5 5、7 7、3 3 ;逆序,互换;逆序,互换4 4、1 1、2 2、5 5、6 6、7 7、3 3 ;逆序,互换;逆序,互换4 4、1 1、2 2、5 5、6 6、7 7、3 3 ;正序,不互换;正序,不互换4 4、1 1、2 2、5 5、6 6、3 3、7

48、 7 ;逆序,互换,第一次冒泡结束;逆序,互换,第一次冒泡结束如此进行,各次冒泡的结果如下如此进行,各次冒泡的结果如下:第第1 1次冒泡结果:次冒泡结果:4 4、1 1、2 2、5 5、6 6、3 3、7 7第第2 2次冒泡结果:次冒泡结果:1 1、2 2、4 4、5 5、3 3、6 6、7 7第第3 3次冒泡结果:次冒泡结果:1 1、2 2、4 4、3 3、5 5、6 6、7 7第第4 4次冒泡结果:次冒泡结果:1 1、2 2、3 3、4 4、5 5、6 6、7 7 ;已完成排序;已完成排序第第5 5次冒泡结果:次冒泡结果:1 1、2 2、3 3、4 4、5 5、6 6、7 7第第6 6次冒

49、泡结果:次冒泡结果:1 1、2 2、3 3、4 4、5 5、6 6、7 7 对于对于n n个数,理论上应进行(个数,理论上应进行(n-1n-1)次冒泡,有时不到()次冒泡,有时不到(n-1n-1)次)次就已完成排序就已完成排序 。如何判定如何判定排序是否已完成排序是否已完成,看各次冒泡中是,看各次冒泡中是否有互换发生否有互换发生,如,如有数据互换,则排序未完成。有数据互换,则排序未完成。在程序设计中,常使用在程序设计中,常使用设置互换标志设置互换标志的方法,该标志的状态表的方法,该标志的状态表示在一次冒泡中是否有互换进行。示在一次冒泡中是否有互换进行。例例4-94-9 一批单字节无符号数,以一

50、批单字节无符号数,以R0R0为首地址指针,为首地址指针,R2R2中为字节中为字节数,将这批数进行升序排列。程序框图如数,将这批数进行升序排列。程序框图如图图4-24-2所示。所示。 图图4-24-2SORTSORT:MOV AMOV A,R0 R0 ;MOV R1MOV R1,A AMOV AMOV A,R2R2;字节数送入;字节数送入R5R5MOV R5MOV R5,A ACLR F0CLR F0;互换标志位;互换标志位F0F0清零清零DEC R5DEC R5;MOV AMOV A,R1R1;LOOP:LOOP:MOV R3MOV R3,A A;INC R1INC R1;CLR CCLR C

51、; MOV AMOV A,R1R1;比较大小;比较大小SUBB ASUBB A,R3R3 ;JNC LOOP1JNC LOOP1 ;SETB F0SETB F0;互换标志位;互换标志位F0F0置置1 1MOV AMOV A,R3R3;XCH AXCH A,R1R1;两个数互换;两个数互换DEC R1DEC R1;XCH AXCH A,R1R1;INC R1INC R1LOOP1LOOP1:MOV AMOV A,R1 R1 DJNZ R5DJNZ R5,LOOP LOOP JB F0JB F0,SORT SORT RETRET4.3.7 4.3.7 分支转移程序设计分支转移程序设计特点是程序中含

52、有转移指令,转移指令有分为特点是程序中含有转移指令,转移指令有分为无条件无条件转移转移和和有条件转移有条件转移,因此分支程序也可分为无条件,因此分支程序也可分为无条件分支转移程序和有条件分支转移程序。有条件分支分支转移程序和有条件分支转移程序。有条件分支转移程序按结构类型来分,又分为转移程序按结构类型来分,又分为单分支转移单分支转移结构结构和和多分支转移多分支转移结构。结构。一、分支转移结构一、分支转移结构 1 1单分支转移结构单分支转移结构 仅有两个出口,两者选一。仅有两个出口,两者选一。例例4-104-10 求单字节有符号数的二进制补码求单字节有符号数的二进制补码, ,程序框图如程序框图如

53、图图4-34-3所所示示: : 参考程序:参考程序:CMPTCMPT:JNB Acc.7,RETURNJNB Acc.7,RETURN;(;(A A)00,不需转换,不需转换MOV CMOV C,Acc.7Acc.7 ;符号位保存;符号位保存CPL ACPL A ;(;(A A)求反,加)求反,加1 1ADD AADD A,#1#1 ; MOV Acc.7MOV Acc.7,C C;符号;符号位存位存A A的最高位的最高位RETURNRETURN:RETRET图图4-34-3此外,单分支选择结构还有如此外,单分支选择结构还有如图图4-44-4、图、图4-54-5等所示的几种形式:等所示的几种形

54、式: 图图4-44-4图图4-54-52多分支转移结构多分支转移结构 程序的判别部分有两个以上的出口流向。程序的判别部分有两个以上的出口流向。常见的两种形式。如常见的两种形式。如图图4-64-6和和图图4-74-7。 指令系统提供了非常有用的指令系统提供了非常有用的两种多分支选择指令两种多分支选择指令: : 间接转移指令间接转移指令: : JMP A+DPTR;JMP A+DPTR;比较转移指令比较转移指令: : CJNE A,direct,relCJNE A,direct,rel; CJNE A,#data,relCJNE A,#data,rel; CJNE Rn,#data,relCJNE

55、 Rn,#data,rel;CJNE Ri,#data,relCJNE Ri,#data,rel; 图图4-64-6图图4-74-7最简单的分支转移程序的设计,一般常采用逐次比较法,就是最简单的分支转移程序的设计,一般常采用逐次比较法,就是把所有不同的情况一个一个的进行比较,发现符合就转向把所有不同的情况一个一个的进行比较,发现符合就转向对应的处理程序。这种方法的主要缺点是程序太长,有对应的处理程序。这种方法的主要缺点是程序太长,有n n种种可能的情况,就需有可能的情况,就需有n n个判断和转移。个判断和转移。 例例4-114-11 求符号函数的值求符号函数的值。符号函数定义符号函数定义( (

56、略略) ):X X存放在存放在40H40H单元,单元,Y Y存放在存放在41H41H单元,程序框图如单元,程序框图如图图4-64-6所示。所示。程序如下:程序如下:SIGNFUC:SIGNFUC:MOV MOV A,40HA,40HCJNE CJNE A,#00H,NZEARA,#00H,NZEARAJMP AJMP NEGTNEGTNZEAR:NZEAR:JB JB Acc.7, POSIAcc.7, POSIMOV MOV A,#01HA,#01HAJMP AJMP NEGTNEGTPOSI:POSI:MOV MOV A,#81HA,#81HNEGT:NEGT:MOV MOV 41H, A

57、41H, AENDEND在实际的应用中,经常遇到的在实际的应用中,经常遇到的图图4-74-7结构形式的分支转移程序结构形式的分支转移程序的设计的设计 需根据某一单元的内容是需根据某一单元的内容是0 0,1 1,n n,来分别转向处理程,来分别转向处理程序序0 0,处理程序,处理程序1 1,处理程序处理程序n n。一个一个典型的例子典型的例子就是当单片机系统中的就是当单片机系统中的键盘按下时,键盘按下时,就会得就会得到一个键值,到一个键值,根据不同的键值,跳向不同的键处理程序入根据不同的键值,跳向不同的键处理程序入口。口。对于这种情况,可用直接转移指令(对于这种情况,可用直接转移指令(LJMPL

58、JMP或或AJMPAJMP指令)指令)组成一个转移表,然后把该单元的内容读入累加器组成一个转移表,然后把该单元的内容读入累加器A A,转,转移表首地址放入移表首地址放入DPTRDPTR中,再利用间接转移指令实现分支转中,再利用间接转移指令实现分支转移。移。 例例4-124-12 根据寄存器根据寄存器R2R2的内容,转向各个处理程序的内容,转向各个处理程序PRGXPRGX(X=0-X=0-n n)。)。(R2R2)=0=0,转,转PRG0PRG0(R2R2)=1=1,转,转PRG1PRG1 (R2R2)=n, =n, 转转PRGnPRGn4.3.8 4.3.8 循环程序设计循环程序设计 特点是程

59、序中含有可以反复执行的程序段,该程序段通常称为特点是程序中含有可以反复执行的程序段,该程序段通常称为循环体。例如求循环体。例如求100100个数的累加和,则没有必要连续安排个数的累加和,则没有必要连续安排100100条加法指令,可以只用一条加法指令并使其循环执行条加法指令,可以只用一条加法指令并使其循环执行100100次。次。 (1 1)可大大缩短程序长度)可大大缩短程序长度 (2 2)使程序所占的内存单元数量少)使程序所占的内存单元数量少 (3 3)使程序结构紧凑和可读性变好。)使程序结构紧凑和可读性变好。1. 1. 循环程序的结构循环程序的结构循环结构程序主要由以下四部分组成。循环结构程序

60、主要由以下四部分组成。 (1 1)循环初始化)循环初始化循环初始化程序段用于完成循环前的的准备工作。例如,循环循环初始化程序段用于完成循环前的的准备工作。例如,循环控制计数初值的设置、地址指针的起始地址的设置、为变控制计数初值的设置、地址指针的起始地址的设置、为变量预置初值等。量预置初值等。 (2 2)循环处理)循环处理循环程序结构的核心部分,完成实际的处理工作,是需反复循循环程序结构的核心部分,完成实际的处理工作,是需反复循环执行的部分,故又称循环体。这部分程序的内容,取决于环执行的部分,故又称循环体。这部分程序的内容,取决于实际处理问题的本身。实际处理问题的本身。(3 3)循环控制)循环控

温馨提示

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

评论

0/150

提交评论