收藏 分销(赏)

汇编-语言程序设计.pptx

上传人:w****g 文档编号:4224505 上传时间:2024-08-26 格式:PPTX 页数:74 大小:565.29KB
下载 相关 举报
汇编-语言程序设计.pptx_第1页
第1页 / 共74页
汇编-语言程序设计.pptx_第2页
第2页 / 共74页
汇编-语言程序设计.pptx_第3页
第3页 / 共74页
汇编-语言程序设计.pptx_第4页
第4页 / 共74页
汇编-语言程序设计.pptx_第5页
第5页 / 共74页
点击查看更多>>
资源描述

1、1第第4 4章章 AT89S51AT89S51汇编语汇编语 言程序设计言程序设计12 2第第4章章目录目录4.1汇编语言程序设计概述汇编语言程序设计概述4.1.1单片机编程语言4.1.2汇编语言语句和格式4.1.3伪指令4.2汇编语言源程序的汇编汇编语言源程序的汇编4.2.1手工汇编4.2.2机器汇编34.3AT89S51汇编语言程序设计举例汇编语言程序设计举例4.3.1子程序的设计4.3.2查表程序设计4.3.3关键字查找程序设计4.3.4数据极值查找程序设计4.3.5数据排序程序设计4.3.6分支转移程序设计4.3.7循环程序设计4内容概要内容概要汇编语言能汇编语言能直接控制单片机硬件直接

2、控制单片机硬件的的编程语言编程语言。因此,要求程序设计者要因此,要求程序设计者要 “软、硬结合软、硬结合”。本章介绍汇编语言程序设计的本章介绍汇编语言程序设计的基本知识基本知识,以及一些以及一些基本的基本的程序设计程序设计。4.1汇编语言程序设计概述汇编语言程序设计概述程序是指令的有序集合。程序是指令的有序集合。单片机运行就是执行指令序列的过程。单片机运行就是执行指令序列的过程。编写这一指令序列的过程称为编写这一指令序列的过程称为程序设计。程序设计。54.1.1 4.1.1 单片机编程语言单片机编程语言常用的编程语言是常用的编程语言是汇编语言汇编语言和和高级语言高级语言。1 1汇编语言汇编语言

3、用英文字符来代替机器语言,这些英文字符被称为用英文字符来代替机器语言,这些英文字符被称为助记符汇助记符汇编语言:编语言:用助记符表示的指令。用助记符表示的指令。汇编语言源程序:汇编语言源程序:用汇编语言编写的程序。用汇编语言编写的程序。“汇编汇编”:汇编语言源程序需汇编语言源程序需转换(翻译)转换(翻译)成为二进制代码成为二进制代码表示的机器语言程序,才能识别和执行。表示的机器语言程序,才能识别和执行。完成完成“翻译翻译”的程序称为的程序称为汇编程序汇编程序。经汇编程序。经汇编程序“汇编汇编”得得到的以到的以“0 0”、“1 1”代码形式表示的机器语言程序称为代码形式表示的机器语言程序称为目标

4、目标程序程序。56优点:优点:用汇编语言编写程序效率高,占用存储空间小,运行用汇编语言编写程序效率高,占用存储空间小,运行速度快,能编写出最优化的程序,速度快,能编写出最优化的程序,缺点:缺点:可读性差,离不开具体的硬件,是面向可读性差,离不开具体的硬件,是面向“硬件硬件”的语的语言通用性差。言通用性差。2 2高级语言高级语言不受具体不受具体“硬件硬件”的限制,的限制,优点:优点:通用性强,直观、易懂、通用性强,直观、易懂、易学,可读性好。易学,可读性好。目前多数的目前多数的51单片机用户单片机用户使用使用C语言(语言(C51)来进行程序设来进行程序设计,已公认为高级语言中高效简洁而又贴近计,

5、已公认为高级语言中高效简洁而又贴近51单片机硬件的编单片机硬件的编程语言。程语言。将将C语言向单片机上移植,始于语言向单片机上移植,始于20世纪世纪80年代的中后期。年代的中后期。67经过十几年努力,经过十几年努力,C51C51已成为单片机的实用高级编程语言。已成为单片机的实用高级编程语言。尽管目前已有不少设计人员使用尽管目前已有不少设计人员使用C51C51来进行程序开发,但在来进行程序开发,但在对对程序的程序的空间空间和和时间时间要求较高的场合,汇编语言仍必不可少。要求较高的场合,汇编语言仍必不可少。在这种场合下,可使用在这种场合下,可使用C C语言和汇编语言混合编程。在很多语言和汇编语言混

6、合编程。在很多需要直接控制硬件且对实时性要求较高的场合,则更是非用汇需要直接控制硬件且对实时性要求较高的场合,则更是非用汇编语言不可。编语言不可。掌握汇编语言并能进行程序设计,是学习和掌握单片机程掌握汇编语言并能进行程序设计,是学习和掌握单片机程序设计的序设计的基本功之一基本功之一。4.1.2 4.1.2 汇编语言语句和格式汇编语言语句和格式两种基本语句:两种基本语句:指令语句指令语句和和伪指令语句伪指令语句。78(1 1)指令语句)指令语句已在第已在第3 3章介绍。每一指令语句在汇编时都产生一个指令代码章介绍。每一指令语句在汇编时都产生一个指令代码(机器代码),执行该指令代码对应着机器的一种

7、操作。(机器代码),执行该指令代码对应着机器的一种操作。(2 2)伪指令语句)伪指令语句是控制汇编(翻译)过程的一些是控制汇编(翻译)过程的一些控制命令控制命令。在汇编时。在汇编时没有机器没有机器代码代码与之对应。与之对应。下面介绍指令语句格式。伪指令语句将在下面介绍指令语句格式。伪指令语句将在4.1.34.1.3节介绍。节介绍。9汇编语言语句是符合典型的汇编语言的汇编语言语句是符合典型的汇编语言的四分段四分段格式格式:标号字段标号字段和和操作码字段操作码字段之间要有之间要有冒号冒号“:”分隔;分隔;操作码字段操作码字段和和操作数字段间操作数字段间的分界符是的分界符是空格空格;双操作数双操作数

8、之间用之间用逗号逗号相隔;相隔;操作数字段操作数字段和和注释字段注释字段之间的分界符用之间的分界符用分号分号“;”。任何语句都必须有操作码字段任何语句都必须有操作码字段,其余各段为任选项。,其余各段为任选项。9标号字段标号字段(LABLE)操作码字段操作码字段(OPCODE)操作数字段操作数字段(OPRAND)注释字段注释字段(COMMENT)10【例例4-1】下面是一段程序的下面是一段程序的四分段四分段书写格式。书写格式。标号字段标号字段 操作码字段操作码字段 操作数字段操作数字段 注释字段注释字段START:MOVA,#00H;0AMOVR1,#10;10R1MOVR2,#00000011

9、B;03HR2LOOP:ADDA,R2;(A)+(R2)ADJNZR1,LOOP;R1减减1不为零,则跳不为零,则跳LOOP处处NOPHERE:SJMPHERE上述上述4个字段应该遵守的个字段应该遵守的基本语法规则基本语法规则如下。如下。10111 1标号字段标号字段语句所在地址的标志符号,才能被访问。如标号语句所在地址的标志符号,才能被访问。如标号“STARTSTART”和和“LOOPLOOP”等。有关标号规定如下:等。有关标号规定如下:(1 1)标号后必须跟冒号标号后必须跟冒号“:”。(2 2)标号由标号由1 18 8个个ASCIIASCII码字符组成,第一个字符必须是码字符组成,第一个字

10、符必须是字母。字母。(3 3)同一标号在一个程序中只能定义一次,不能重复定同一标号在一个程序中只能定义一次,不能重复定义。义。(4 4)不能使用汇编语言已经定义的符号作为标号,如指不能使用汇编语言已经定义的符号作为标号,如指令助记符、伪指令以及寄存器的符号名称等。令助记符、伪指令以及寄存器的符号名称等。(5 5)标号的有无,取决于本程序中的其他语句是否访标号的有无,取决于本程序中的其他语句是否访1112问该条语句。如无其他语句访问,则该语句前不需标号。问该条语句。如无其他语句访问,则该语句前不需标号。2 2操作码字段操作码字段操作码字段规定了语句执行的操作,操作码是汇编语言指令中操作码字段规定

11、了语句执行的操作,操作码是汇编语言指令中唯一不能空缺的部分。唯一不能空缺的部分。3 3操作数字段操作数字段指令的操作数或操作数地址。指令的操作数或操作数地址。在本字段中,在本字段中,操作数的个数因指令的不同而不同。操作数的个数因指令的不同而不同。通常有单操通常有单操作数、双操作数和无操作数三种情况。作数、双操作数和无操作数三种情况。如果是多操作数,则操作数之间要以如果是多操作数,则操作数之间要以逗号逗号隔开。隔开。13操作数表示操作数表示时,几种情况需注意:时,几种情况需注意:(1 1)十六进制、二进制和十进制形式的操作数表示)十六进制、二进制和十进制形式的操作数表示多数情况,操作数或操作数地

12、址是采用多数情况,操作数或操作数地址是采用十六进制十六进制形式来表形式来表示的。则需加示的。则需加后缀后缀“H H”。在某些特殊场合用在某些特殊场合用二进制二进制表示,需加表示,需加后缀后缀“B B”若操作数采用若操作数采用十进制十进制形式,则需加形式,则需加后缀后缀“D D”,也可省略。,也可省略。若十六进制若十六进制操作数操作数以以字符字符A AF F开头开头,需在它,需在它前面加一个前面加一个 “0 0”,以便汇编时把它和,以便汇编时把它和字符字符A AF F区别区别开。开。1314(2 2)工作寄存器和特殊功能寄存器的表示)工作寄存器和特殊功能寄存器的表示 当操作数为工作寄存器或特殊功

13、能寄存器时,允许用当操作数为工作寄存器或特殊功能寄存器时,允许用工作寄存器和特殊功能寄存器的工作寄存器和特殊功能寄存器的代号表示代号表示。例如,例如,工作寄存器用工作寄存器用R7R7R0R0,累加器用,累加器用A A(或(或AccAcc)表)表示。另外,工作寄存器和特殊功能寄存器也可用其地址来示。另外,工作寄存器和特殊功能寄存器也可用其地址来表示,如累加器表示,如累加器A A可用其地址可用其地址E0HE0H来表示。来表示。4 4注释字段注释字段用于解释指令或程序的含义,对可读性非常有用。用于解释指令或程序的含义,对可读性非常有用。使用时使用时须以分号开头须以分号开头,长度不限,一行写不下,长度

14、不限,一行写不下可换行可换行书写,但注意也要以分号开头。书写,但注意也要以分号开头。1415 汇编时,遇到汇编时,遇到“;”就停止就停止“翻译翻译”。因此,注释字。因此,注释字段不会产生机器代码。段不会产生机器代码。4.1.3 4.1.3 伪指令伪指令 在汇编语言源程序中应有在汇编语言源程序中应有向汇编程序发出的指示信息向汇编程序发出的指示信息,告诉它如何完成汇编工作,这是通过告诉它如何完成汇编工作,这是通过伪指令伪指令来实现。来实现。伪指令不属于指令系统中的汇编语言指令,它伪指令不属于指令系统中的汇编语言指令,它是程序员是程序员发给汇编程序的发给汇编程序的命令命令,也称为,也称为汇编程序控制

15、命令汇编程序控制命令。只有在汇编前的源程序中才有伪指令。只有在汇编前的源程序中才有伪指令。“伪伪”体现在体现在汇编后,伪指令汇编后,伪指令没有相应的机器代码产生。没有相应的机器代码产生。伪指令具有控制汇编程序的输入伪指令具有控制汇编程序的输入/输出、定义数据和符输出、定义数据和符号、条件汇编、分配存储空间等功能。号、条件汇编、分配存储空间等功能。1516不同汇编语言的伪指令有所不同,但基本内容相同。不同汇编语言的伪指令有所不同,但基本内容相同。介绍介绍常用的伪指令常用的伪指令。1ORG(ORiGin)汇编起始地址命令)汇编起始地址命令源程序的开始,用一条源程序的开始,用一条ORG伪指令规定伪指

16、令规定程序的起始地程序的起始地址址。如果不用如果不用ORG,则汇编得到的目标程序,则汇编得到的目标程序将从将从0000H地地址开始。例如:址开始。例如:ORG2000HSTART:MOVA,#00H即规定标号即规定标号START代表地址为代表地址为2000H开始。开始。在一源程序中,可多次用在一源程序中,可多次用ORG指令,规定不同的程序段的指令,规定不同的程序段的起始地址。但是,起始地址。但是,地址必须由小到大排列,且不能交叉、地址必须由小到大排列,且不能交叉、17重叠。例如:重叠。例如:ORG2000HORG2500HORG3000H这种顺序是正确的。若按下面顺序的排列则是错误的,因为地址

17、出现了交叉。ORG2500HORG2000HORG3000H17182.2.END(END of Assembly)END(END of Assembly)汇编终止命令汇编终止命令源程序源程序结束标志结束标志,终止源程序的汇编工作。终止源程序的汇编工作。整个源程序整个源程序中只能有一条中只能有一条ENDEND命令,且命令,且位于程序的最后位于程序的最后。如果。如果ENDEND出现出现在程序中间,其后的源程序,将不进行汇编处理。在程序中间,其后的源程序,将不进行汇编处理。3 3EQUEQU(EQUateEQUate)标号赋值命令)标号赋值命令用于用于给标号赋值给标号赋值。赋值后,标号值在整个程序

18、有效。赋值后,标号值在整个程序有效。例如:例如:TESTTEST:EQU 2000HEQU 2000H表示表示TEST=2000HTEST=2000H,汇编时,凡是遇到,汇编时,凡是遇到TESTTEST时,均以时,均以2000H2000H来代替。来代替。18194DB(DefineByte)定义数据字节命令)定义数据字节命令用于从指定的地址开始,在程序存储器连续单元中定义用于从指定的地址开始,在程序存储器连续单元中定义字节数据。例如:字节数据。例如:ORG 2000HDB30H,40H,24,C,B汇编后汇编后(2000H)=30H(2001H)=40H(2002H)=18H(十进制数十进制数

19、24)(2003H)=43H(字符字符“C”的的ASCII码码)(2004H)=42H(字符字符“B”的的ASCII码码)1920显然,显然,DB功能是从指定单元开始定义(存储)若干字节,功能是从指定单元开始定义(存储)若干字节,十进制数自然转换成十六进制数,字母按十进制数自然转换成十六进制数,字母按ASCII码存储。码存储。5DW(DefineWord)定义数据字命令)定义数据字命令该命令用于从指定的地址开始,在程序存储器的连续单元中该命令用于从指定的地址开始,在程序存储器的连续单元中定义定义16位的数据字。例如:位的数据字。例如:ORG2000HDW1246H,7BH,10汇编后(2000

20、H)=12H;第1个字(2001H)=46H(2002H)=00H;第2个字21(2003H)=7BH(2004H)=00H;第;第3个字个字(2005H)=0AH6DS(DefineStorage)定义存储区命令)定义存储区命令从指定地址开始,保留指定数目的字节单元作为存储区,从指定地址开始,保留指定数目的字节单元作为存储区,供程序运行使用。供程序运行使用。例如:例如:TABEL:DS10表示从表示从TABEL代表的地址开始,保留代表的地址开始,保留10个连续的地址单个连续的地址单元。元。又例如又例如:ORG2000HDS10H表示从表示从2000H地址开始,保留地址开始,保留16个连续地址

21、单元。个连续地址单元。2122注意:注意:DBDB、DWDW和和DSDS命令命令只能对程序存储器有效,只能对程序存储器有效,不能对不能对数据存储器数据存储器使用。使用。7 7BIT BIT 位定义命令位定义命令用于给字符名称赋以位地址,位地址可以是绝对位地用于给字符名称赋以位地址,位地址可以是绝对位地址,也可是符号地址。例如:址,也可是符号地址。例如:QAQABIT P1.6BIT P1.6功能是把功能是把P1.6P1.6的位地址赋给变量的位地址赋给变量QAQA。4.2 4.2 汇编语言源程序的汇编汇编语言源程序的汇编“汇编汇编”?汇编可分为?汇编可分为手工汇编手工汇编和和机器汇编机器汇编两类

22、。两类。22234.2.1 4.2.1 手工汇编手工汇编 通过查指令的通过查指令的机器代码表(表机器代码表(表3-23-2),),逐个把助记符指令逐个把助记符指令“翻译翻译”成机器代码,再进行调试和运行。成机器代码,再进行调试和运行。手工汇编手工汇编遇到相对转移偏移量的计算时,较麻烦,易出遇到相对转移偏移量的计算时,较麻烦,易出错,只有小程序或受条件限制时才使用。实际中,多采用错,只有小程序或受条件限制时才使用。实际中,多采用“汇汇编程序编程序”来自动完成汇编。来自动完成汇编。23244.2.2 4.2.2 机器汇编机器汇编 用微型计算机上的用微型计算机上的软件软件(汇编程序汇编程序)来代替手

23、工汇编。在微来代替手工汇编。在微机上用编辑软件进行源程序编辑,然后生成一个机上用编辑软件进行源程序编辑,然后生成一个ASCIIASCII码文件,码文件,扩展名为扩展名为 “.ASM.ASM”。在微机上运行汇编程序,译成机器码。在微机上运行汇编程序,译成机器码。机器码通过微机的串口(或并口)传送到用户样机(或在机器码通过微机的串口(或并口)传送到用户样机(或在线仿真器),进行程序的调试和运行。线仿真器),进行程序的调试和运行。有时,在分析某些产品的程序的机器代码时,有时,在分析某些产品的程序的机器代码时,需将需将机器代机器代码码翻译成翻译成汇编语言源程序汇编语言源程序,称为,称为“反汇编反汇编”

24、。2425【例例4-2】表4-1是一段源程序的汇编结果,可查表3-2,手工汇编,来验证下面的汇编结果是否正确。机器码从1000H单元开始存放。25264.3 AT89S514.3 AT89S51汇编语言程序设计举例汇编语言程序设计举例 介绍常用的汇编语言程序的设计。介绍常用的汇编语言程序的设计。4.3.1 4.3.1 子程序的设计子程序的设计 将那些需多次应用的、完成相同的某种基本运算或操作将那些需多次应用的、完成相同的某种基本运算或操作的程序段从整个程序中独立出来,单独编成一个程序段,的程序段从整个程序中独立出来,单独编成一个程序段,需要时进行调用。这样的程序段称为需要时进行调用。这样的程序

25、段称为子程序子程序。优点:优点:采用子程序可使程序结构简单,缩短程序的设计采用子程序可使程序结构简单,缩短程序的设计时间,减少占用的程序存储空间。时间,减少占用的程序存储空间。子程序在程序设计中非常重要,读者应熟练掌握子程序子程序在程序设计中非常重要,读者应熟练掌握子程序的设计方法。的设计方法。26271 1子程序的设计原则和应注意的问题子程序的设计原则和应注意的问题编写子程序应注意以下问题:编写子程序应注意以下问题:(1 1)子程序的入口地址,前必须有标号。)子程序的入口地址,前必须有标号。(2 2)主程序调用子程序,是通过调用指令来实现。有)主程序调用子程序,是通过调用指令来实现。有两条两

26、条子程序调用指令子程序调用指令:绝对调用指令绝对调用指令ACALL addr11ACALL addr11。双字节,。双字节,addr11addr11指出了指出了调用的目的地址,调用的目的地址,PCPC中中1616位地址中的高位地址中的高5 5位不变,被调用的位不变,被调用的子程序的首地址与绝对调用指令的下一条指令的高子程序的首地址与绝对调用指令的下一条指令的高5 5位地址位地址相同,即只能在同一个相同,即只能在同一个2KB2KB区内。区内。长调用指令长调用指令LCALL addr16LCALL addr16。三字节,三字节,addr16addr16为直接调为直接调用的目的地址,子程序可放在用的

27、目的地址,子程序可放在64KB64KB程序存储器区任意位置。程序存储器区任意位置。2728(3 3)子程序结构中必须用到)子程序结构中必须用到堆栈堆栈,用来进行断点和现场的保,用来进行断点和现场的保护。护。(4 4)子程序返回主程序时,)子程序返回主程序时,最后一条指令必须是最后一条指令必须是RETRET指令指令,功能是把功能是把堆栈中的断点地址堆栈中的断点地址弹出送入弹出送入PCPC指针中,从而实现子程指针中,从而实现子程序返回后从主程序断点处继续执行主程序。序返回后从主程序断点处继续执行主程序。(5 5)子程序可以)子程序可以嵌套嵌套,即主程序可以调用子程序,子程序又,即主程序可以调用子程

28、序,子程序又可以调用另外的子程序。可以调用另外的子程序。28292子程序的基本结构子程序的基本结构典型的子程序的基本结构如下:MAIN:;MAIN为主程序入口标号LCALLSUB;调用子程序SUB子程序SUB:PUSH PSW;现场保护 PUSH AccPOPAcc;现场恢复,注意要先进后出POPPSWRET;最后一条指令必须为RET29子程序处理程序段子程序子程序30 注意:注意:上述子程序结构中,现场保护与现场恢复不是必需上述子程序结构中,现场保护与现场恢复不是必需的,要根据实际情况而定。的,要根据实际情况而定。4.3.2 4.3.2 查表程序设计查表程序设计 查表程序是一种常用程序查表程

29、序是一种常用程序,避免避免复杂的运算或转换过程,复杂的运算或转换过程,可完成数据补偿、修正、计算、转换等各种功能,具有程序简可完成数据补偿、修正、计算、转换等各种功能,具有程序简单、执行速度快等单、执行速度快等优点优点。查表查表是根据是根据自变量自变量x x,在表格,在表格寻找寻找y y,使,使y y=f f(x x)。单片机。单片机中,数据表格存放于中,数据表格存放于程序存储器程序存储器内,在执行查表指令时,发出内,在执行查表指令时,发出读程序存储器选通脉冲读程序存储器选通脉冲 。两条两条极为有用的查表指令如下:极为有用的查表指令如下:(1 1)MOVC MOVC A A,A+DPTRA+D

30、PTR(2 2)MOVC MOVC A A,A+PCA+PC3031两条指令的功能完全相同,具体使用有差别。两条指令的功能完全相同,具体使用有差别。指令指令“MOVC AMOVC A,A+DPTRA+DPTR”把把A A中内容与中内容与DPTRDPTR中的内容相加,中的内容相加,结果为某一程序存储单元的地址,然后把该地址单元的内容送结果为某一程序存储单元的地址,然后把该地址单元的内容送到到A A中。中。指令指令“MOVC AMOVC A,A+PCA+PC”,PCPC的内容与的内容与A A的内容相加后所得的内容相加后所得的数作为某一程序存储器单元的地址,根据地址取出程序存储的数作为某一程序存储器

31、单元的地址,根据地址取出程序存储器相应单元中的内容送到累加器器相应单元中的内容送到累加器A A,指令执行后,指令执行后,PCPC的内容不发的内容不发生变化,仍指向该查表指令的下一条指令。生变化,仍指向该查表指令的下一条指令。优点:优点:在于预处理较少且不影响其他特殊功能寄存器的值,在于预处理较少且不影响其他特殊功能寄存器的值,不必保护其他特殊功能寄存器。不必保护其他特殊功能寄存器。3132缺点:缺点:在于该表格只能存放在这条指令的地址在于该表格只能存放在这条指令的地址X3X2X1X0X3X2X1X0以下以下00H00HFFHFFH之中,即只能存放在地址范围之中,即只能存放在地址范围X3X2X1

32、X0+1X3X2X1X0+1X3X2X1X0+100HX3X2X1X0+100H中,这就使得表格所在的程序空间受到了中,这就使得表格所在的程序空间受到了限制。限制。下面说明下面说明查表指令的用法查表指令的用法和和计算偏移量计算偏移量应注意的问题。应注意的问题。33【例例4-3】设计一子程序,功能是根据累加器A中的数x(09之间)查x的平方表y,根据x的值查出相应的平方y。本例中的x和y均为单字节数。地地 址址 子程序子程序Y3Y2Y1Y0ADDA,#01HY3Y2Y1Y0+2MOVCA,A+PCY3Y2Y1Y0+3RETY3Y2Y1Y0+4DB00H,01H,04H,09H,10HDB19H,

33、24H,31H,40H,51H;数09的平方表3334指令指令“ADD AADD A,#01H#01H”的作用的作用是是A A中的内容加上中的内容加上 “01H01H”,“01H01H”即为查表指令与平方表之间的即为查表指令与平方表之间的“RETRET”指令所占的字节数。加上指令所占的字节数。加上 “01H01H”后,可保证后,可保证PCPC指向表首,指向表首,累加器累加器A A中原来的内容仅是从表首开始向下查找多少个单中原来的内容仅是从表首开始向下查找多少个单元。元。在进入程序前,在进入程序前,A A的内容在的内容在000009H09H之间,如之间,如A A中的内容中的内容为为02H02H,

34、它的平方为,它的平方为04H04H,可根据,可根据A A的内容查出的内容查出x x的平方的平方指令指令“MOVC AMOVC A,A+DPTRA+DPTR”应用范围较广,使用该指应用范围较广,使用该指令时不必计算偏移量,优点是表格可以设在令时不必计算偏移量,优点是表格可以设在64KB64KB程序存储程序存储器空间内的任何地方,而不像器空间内的任何地方,而不像“MOVC AMOVC A,A+PCA+PC”那样只那样只设在设在PCPC下面的下面的256256个单元中,所以使用较方便。个单元中,所以使用较方便。3435如果DPTR已被使用,则在查表前必须保护DPTR,且结束后恢复DPTR,例4-3可

35、改成如下形式:PUSHDPH;保存DPHPUSHDPL;保存DPLMOVDPTR,#TAB1MOVC A,A+DPTRPOPDPL;恢复DPLPOPDPH;恢复DPHRETTAB1:DB00H,01H,04H,09H,10H;平方表DB19H,24H,31H,40H,51H实际查表,有时x为单字节数,y为双字节数。来看下例。3536【例例4-4】有一巡回检测报警装置,需对16路(x)输入进行检测,每路有一个最大允许值(y),为双字节数。需根据测量的路数(x),查表找出对应该路的最大允许值(y),看输入值是否大于最大允许值,如果大于就报警。取路数为x(0 x15),y为最大允许值,放在表格中。设

36、进入查表程序前,假设路数x已放于R2中,查表后该路的最大允许值y放于R3R4中。查表的程序如下:3637TB3:MOVA,R2ADDA,R2;(R2)*2(A)MOVR3,A;保存指针 ADDA,#6;加偏移量MOVCA,A+PC;查第一字节XCH A,R3ADD A,#3MOVCA,A+PC;查第二字节MOVR4,ARETTAB3:DW1520,3721,42645,7580;最大值表DW3483,32657,883,9943DW10000,40511,6758,8931DW4468,5871,13284,278083738表格长度不能超过表格长度不能超过256B256B,且表格只能存放于,

37、且表格只能存放于“MOVC AMOVC A,A+PCA+PC”指令以下的指令以下的256256个单元中,如需把表格放在程序存储个单元中,如需把表格放在程序存储器空间的任何地方,应使用指令器空间的任何地方,应使用指令“MOVC AMOVC A,A+DPTRA+DPTR”。【例例4-54-5】以以AT89S51AT89S51为核心的温度控制器,温度传感器为核心的温度控制器,温度传感器输出的电压与温度为非线性关系,传感器输出的电压已由输出的电压与温度为非线性关系,传感器输出的电压已由A/DA/D转换为转换为1010位二进制数。测得的不同温度下的电压值数据位二进制数。测得的不同温度下的电压值数据构成一

38、个表,表中温度值为构成一个表,表中温度值为y y(双字节无符号数),(双字节无符号数),x x(双字(双字节无符号数)为电压值数据。设测得电压值节无符号数)为电压值数据。设测得电压值x x放入放入R2R3R2R3中,中,根据根据电压值电压值x x,查找对应的,查找对应的温度值温度值y y,仍放入,仍放入R2R3R2R3中。参考程中。参考程序:序:3839LTB2:MOVDPTR,#TAB2MOVA,R3CLRCRLCAMOVR3,AXCHA,R2RLCAXCHR2,AADDA,DPL;(R2R3)+(DPTR)(DPTR)MOVDPL,AMOVA,DPHADDCA,R2MOVDPH,ACLRA

39、3940MOVCA,A+DPTR;查第一字节MOVR2,A;第一字节存入R2中CLRAINCDPTRMOVCA,A+DPTR;查第二字节MOVR3,A;第二字节存入R3中RETTAB2:DW,;温度值表由于使用了指令“MOVCA,A+DPTR”,表TAB2可放入64KB程序存储器空间任何位置,表格的长度可大于256B。40414.3.3关键字查找程序设计关键字查找程序设计在表中查找关键字的操作,也称为数据检索。有两种方法,即顺序检索和对分检索。1顺序检索顺序检索要检索的表是无序无序的,检索时只能从第只能从第1项开始逐项查项开始逐项查找找,判断所取数据是否与关键字相等。【例例4-6】从50个字节

40、的无序表中查找一个关键字“xxH”。ORG1000HMOV30H,#xxH;关键字xxH送30H单元MOVR1,#50;查找次数送R1MOVA,#14;修正值送AMOVDPTR,#TAB4;表首地址送DPTR4142LOOP:PUSHAccMOVCA,A+PC;查表结果送ACJNEA,40H,LOOP1;(40H)不等于关键字则转LOOP1MOVR2,DPH;查到关键字,把地址送R2,R3MOVR3,DPLDONE:RETLOOP1:POP Acc;修正值弹出INC A;A+1AINC DPTR;修改数据指针DPTRDJNZR1,LOOP;R10,未查完,继续查找MOVR2,#00H;R1=0

41、,R2和R3清0MOVR3,#00H;表中50个数已查完AJMPDONE;从子程序返回TAB4:DB,;50个无序数据表42432对分检索对分检索对分检索的前提是检索的数据表已经排好序已经排好序,以便于按照对分原则取数。如何进行数据排序,稍后介绍。对分检索的方法对分检索的方法:取数据表中间位置的数与关键字进行比较,如相等,则查找结束。如果取数大于关键字取数大于关键字,则下次对分检索的范围是从数据区起点到本次取数处。如果取数小于关键字取数小于关键字,则下次对分检索的范围是从本次取数数据区起点到数据区终点。依此类推,逐渐缩小检索范围,减少次数,大大提高查找速度。43444.3.4数据极值查找程序设

42、计数据极值查找程序设计进行数值大小的比较,从一批数据中找出最大最大值(或最小值最小值)并存于某一单元中。【例例4-7】片内RAM中存放一批数据,查找出最大值并存放于首地址中。设R0中存放首地址,R2中存放字节数,程序框图见图4-1。程序如下:MOV R2,n;n为要比较的数据字节数MOV A,R0;存首地址指针MOV R1,ADEC R2MOV A,R145LOOP:MOV R3,ADEC R1CLR CSUBBA,R1;两个数比较JNCLOOP1;C=0,A中数大,跳LOOP1MOVA,R1;C=1,则大数送ASJMPLOOP2LOOP1:MOV A,R3LOOP2:DJNZ R2,LOOP

43、;是否比较结束?MOV R0,A;存最大数RET45464.3.5数据排序程序设计数据排序程序设计将一批数由小到大(升序升序)排列,或由大到小(降序降序)排列。最常用的数据排序算法是冒泡法冒泡法,是相邻数互换的排序方法,因其过程类似水中气泡上浮,故称冒泡法。排序时,从前向后进行相邻两个数的比较从前向后进行相邻两个数的比较,如果数据的大数据的大小次序小次序与要求的顺序不符时要求的顺序不符时,就将两个数互换两个数互换;否则,顺序符合要求就不互换。如果进行升序排序,应通过这种相邻数互换方法,使小数向前移,大数向后移。如此从前向后进行一次次相邻数互换(冒泡),(冒泡),就会把这批数据的最大数排到最后,

44、次大数排在倒数第二的位置,4647从而实现一批数据由小到大的排列。假设有7个原始数据的排列顺序为6、4、1、2、5、7、3。第一次冒泡的过程是:6、4、1、2、5、7、3;原始数据的排列4、6、1、2、5、7、3;逆序,互换4、1、6、2、5、7、3;逆序,互换4、1、2、6、5、7、3;逆序,互换4、1、2、5、6、7、3;逆序,互换4、1、2、5、6、7、3;正序,不互换4、1、2、5、6、3、7;逆序,互换,第一次冒泡结束4748如此进行,各次冒泡的结果如下:如此进行,各次冒泡的结果如下:第第1次冒泡结果:次冒泡结果:4、1、2、5、6、3、7第第2次冒泡结果:次冒泡结果:1、2、4、5

45、、3、6、7第第3次冒泡结果:次冒泡结果:1、2、4、3、5、6、7第第4次冒泡结果:次冒泡结果:1、2、3、4、5、6、7;已完成排序;已完成排序第第5次冒泡结果:次冒泡结果:1、2、3、4、5、6、7第第6次冒泡结果:次冒泡结果:1、2、3、4、5、6、7对于对于n个数个数,理论上应进行(理论上应进行(n-1)次冒泡)次冒泡才能完成排序,才能完成排序,实际上有时不到实际上有时不到(n-1)次)次就已完成排序。就已完成排序。4849例如,上面的例如,上面的7个数个数,应进行,应进行6次次冒泡冒泡,但,但实际上实际上第第4次次冒泡时冒泡时就已经完成就已经完成排序。排序。如何判定排序是否已经完成

46、如何判定排序是否已经完成?就是看各次冒泡中?就是看各次冒泡中是否有是否有互换互换发发生生,如果有,则排序,如果有,则排序还没完成还没完成;否则就表示已经排好序。;否则就表示已经排好序。在程序设计中,常用在程序设计中,常用设置互换标志设置互换标志的方法,用标志的状态表示的方法,用标志的状态表示是否有互换进行。是否有互换进行。【例例4-8】一批单字节无符号数,以一批单字节无符号数,以R0为首地址指针,为首地址指针,R2中为中为字节数,将这批数进行升序排列。程序框图如字节数,将这批数进行升序排列。程序框图如图图4-2所示。程所示。程序如下:序如下:50SORT:MOVA,R0MOVR1,AMOVA,

47、R2;字节数送入R5MOVR5,ACLR F0;互换标志位F0清0DEC R5MOVA,R1LOOP:MOVR3,AINCR1CLR CMOVA,R1;比较大小5051SUBBA,R3JNCLOOP1SETBF0;互换标志位F0置1MOVA,R3;XCH A,R1;两个数互换DECR1XCH A,R1INCR1LOOP1:MOVA,R1DJNZR5,LOOPJBF0,SORTRET515252图图4-24-2 单字节无符号数排序程序框图534.3.6分支转移程序设计分支转移程序设计分为无条件转移分为无条件转移和和有条件转移有条件转移。无条件分支转移程序很简单,不讨论。有条件分支转移程序无条件分

48、支转移程序很简单,不讨论。有条件分支转移程序按结构类型来分,又分为按结构类型来分,又分为单分支单分支选择结构选择结构和和多分支多分支选择结构选择结构。1单分支选择结构单分支选择结构 仅有仅有两个出口两个出口,两者选一两者选一。一般根据运算结果的状态标志,。一般根据运算结果的状态标志,用用条件判跳指令条件判跳指令来选择并转移。来选择并转移。【例例4-9】求单字节有符号数的二进制补码求单字节有符号数的二进制补码正数补码正数补码是其本身,是其本身,负数补码负数补码是其是其反码加反码加1。因此,应首先判。因此,应首先判被转换数的符号,负数进行转换,正数本身即为补码。被转换数的符号,负数进行转换,正数本

49、身即为补码。5354设二进制数放在A中,其补码放回到A中,框图如图图4-3所所示示。参考程序如下:CMPT:JNBAcc.7,RETURN;(A)0,不需转换MOV C,Acc.7;符号位保存CPLA;(A)求反,加1ADD A,#1MOVAcc.7,C;符号位存在A的最高位RETURN:RET5455图图4-34-3 求单字节有符号二进制数补码的框图求单字节有符号二进制数补码的框图56此外,单分支选择结构还有图图4-4、图图4-5所示的几种形式。56图4-4 单分支选择结构2 图4-5 单分支选择结构3572多分支选择结构多分支选择结构当程序的判别部分有两个以上两个以上的出口出口时,为多分支

50、选择结构。有两种形式,如图4-6和图图4-7所示。57 图图4-64-6 多分支选择结构1 1 图图4-74-7 多分支选择结构258指令系统提供了非常有用的指令系统提供了非常有用的两种多分支选择指令两种多分支选择指令:间接转移指令间接转移指令 JMPA+DPTR比较转移指令比较转移指令 CJNEA,direct,relCJNEA,#data,relCJNERn,#data,relCJNERi,#data,rel间接转移指令间接转移指令“JMPA+DPTR”由数据指针由数据指针DPTR决决定多定多分支转移分支转移程序的程序的首地址首地址,由,由A的内容选择对应分支。的内容选择对应分支。4条条比

展开阅读全文
相似文档                                   自信AI助手自信AI助手
猜你喜欢                                   自信AI导航自信AI导航
搜索标签

当前位置:首页 > 通信科技 > 开发语言

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2024 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服