专题 程序设计_第1页
专题 程序设计_第2页
专题 程序设计_第3页
专题 程序设计_第4页
专题 程序设计_第5页
已阅读5页,还剩48页未读 继续免费阅读

下载本文档

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

文档简介

专题程序设计第一页,共五十三页,编辑于2023年,星期六4.1程序设计与汇编一、程序设计步骤

分析确定算法→流程图→源代码→调试仿真二、汇编与反汇编汇编语言←→机器语言手工机器第二页,共五十三页,编辑于2023年,星期六三、伪指令

1、汇编起始指令ORG指令格式为:ORGnn该指令的作用是指明后面的程序或数据块的起始地址,它总是出现在每段源程序或数据块的开始。式中,nn为16位地址,汇编时nn确定了此语句后面第一条指令或第一个数据的地址,此后的源程序或数据块就依次连续存放在以后的地址内,直到遇到另一个ORG指令为止。第三页,共五十三页,编辑于2023年,星期六例:ORG2000HMOVSP,#60HMOVR0,#2FHMOVR2,#0FFHORG伪指令说明其后面程序的目标代码在存储器中存放的起始地址是2000H,即存储器地址目标程序2000H7581602003H782F2005H7AFF第四页,共五十三页,编辑于2023年,星期六2、等值指令EQU指令格式:字符名称EQU数字或汇编符号功能:使指令中的字符名称等价于给定的数字或汇编符号。使用等值指令可给程序的编制、调试、修改带来方便,如果在程序中要多次使用到某一地址,由EQU指令将其赋值给一个字符名称,一旦需要对其进行变动,只要改变EQU命令后面的数字即可,而不需要对程序中涉及到该地址的所有指令逐句进行修改。但要注意,由EQU等值的字符名称必须先赋值后使用,且在同一个源程序中,同一个标号只能赋值一次。例:PA8155EQU8001H;即给标号PA8155赋值为8001H。第五页,共五十三页,编辑于2023年,星期六3、定义字节指令DB指令格式: [标号:]DB8位二进制数表功能:把8位二进制数表依次存入从标号开始的连续的存储单元中。格式中,标号区段可有可无,DB指令之后的8位二进制数表是字节常数或用逗号隔开的字节串,也可以是用引号括起来的ASCII码字符串(一个ASCII字符相当于一个字节)。例:第六页,共五十三页,编辑于2023年,星期六ORG1000HBUF1:DB38H,7FH,80HBUF2:DB45H,66HORG伪指令指定了标号BUF1的地址为1000H,而DB伪指令是将其后的二进制数表38H,7FH,80H依次存放在1000H,1001H,1002H3个连续单元之中,BUF2也是一个标号,其地址与前一条伪指令连续,即1003H,1004H地址单元中依次存放45H,66H。第七页,共五十三页,编辑于2023年,星期六4、定义字指令DW指令格式:[标号:]DW16位数据表该指令的功能与DB相似,区别仅在于从指定地址开始存放的是指令中的16位数据,而不是字节串。每个16位数据要占两个存储单元,高8位先存,低8位后存,这和MCS-51指令中的16位数据存放顺序是一致的。第八页,共五十三页,编辑于2023年,星期六5、汇编结束指令END指令格式:[标号:]END地址或标号格式中标号以及END后面的地址或标号可有可无。功能:提供汇编结束标志。汇编程序遇到END后就停止汇编,对END以后的语句不予处理,故END应放在程序的结束处。第九页,共五十三页,编辑于2023年,星期六4.2汇编语言程序设计4.2.1顺序程序设计例1两个双字节数相加。设有两个16位的双字节数,低8位分别存放在片内20H、30H单元中,高8位分别存放在片内21H、31H单元中,求这两个数的和,结果存放在22H、21H、20H单元中。第十页,共五十三页,编辑于2023年,星期六ORG 0030H ;设置程序存放的起始地址MOV 22H,#00H ;22H单元清零MOV A,20H ;20H中的低8位数送入AADD A,30H ;两个数的低8位相加MOV 20H,A ;低8位相加的结果送入20H中MOV A,21H ;21H中的高8位数送入A中ADDC A,31H ;两数高8位数相加并加低8位进位MOV 21H,A ;高8位相加的结果送入21H中CLR A ;A清零ADDC A,#00H ;加上高位进位MOV 22H,A ;保存最高位进位RET第十一页,共五十三页,编辑于2023年,星期六例2将两个半字节数合并成一个一字节数。设内部RAM40H,41H单元中分别存放着8位二进制数要求取出两个单元中的低半字节,并成一个字节后,存入50H单元中。程序如下:START:MOV R1,#40H ;设置R1为数据指针 MOV A,@R1 ;取出第一个单元中的内容 ANL A,#0FH ;取第一个数的低半字节 SWAP A ;移至高半字节 INC R1 ;修改数据指针 XCH A,@R1 ;取第二个单元中的内容 ANL A,#0FH ;取第二个数的低半字节 ORL A,@R1 ;拼字 MOV 50H,A ;存放结果 RETANL 40H,#0FHANL 41H,#0FHMOV A,40HSWAP AORL A,41HMOV 50H,A第十二页,共五十三页,编辑于2023年,星期六4.2.2分支程序设计图4.1分支结构框图(a)单分支流程;(b)多分支流程第十三页,共五十三页,编辑于2023年,星期六例3x,y均为8位二进制数,设x存入R0,y存入R1,求解:第十四页,共五十三页,编辑于2023年,星期六程序如下:START:CJNER0,#00H,SUL1 ;R0中的数与00比较不等转移 MOVR1,#00H ;相等,R1←0SJMPSUL2SUL1:JCNEG ;两数不等,若(R0)<0, 转向NEGMOVR1,#01H ;(R0)>0,则R1←01H SJMPSUL2NEG:MOVR1,#0FFH ;(R0)<0,则R1=0FFSUL2:RET第十五页,共五十三页,编辑于2023年,星期六

例4比较两个无符号数的大小。设外部RAM的存储单元ST1和ST2中存放两个不带符号的二进制数,找出其中的大数存入外部RAM中的ST3单元中。第十六页,共五十三页,编辑于2023年,星期六程序如下: ORG1000HST1 EQU2000HST2EQU2100HST3EQU2200HSTART:CLRC ;清零Cy MOVDPTR,#ST1;第一个数的指针MOVXA,@DPTR;取第一个数MOVR2,A;保存MOVDPTR,#ST2;第二个数的指针MOVXA,@DPTR;取第二个数CLRC第十七页,共五十三页,编辑于2023年,星期六SUBBA,R2 ;两数比较JNCBIG1 ;若第二个数大,则转XCHA,R2 ;第一个数大BIG0:MOVDPTR,#ST3MOVX@DPTR,A ;存大数RETBIG1:MOVXA,@DPTR ;第二个数大SJMPBIG0RET第十八页,共五十三页,编辑于2023年,星期六散转程序散转程序是分支程序的一种,它可根据运算结果或输入数据将程序转入不同的分支。JMP@A+DPTR该指令把8位无符号数与16位数据指针内容相加,并把结果装入PC,控制程序转向目标地址去执行。此指令的特点在于,转移的目标地址是在程序运行过程中动态地确定的。目标地址由DPTR的内容决定分支转移程序的首地址,由累加器A的内容来动态选择其中的某一个分支转移程序。第十九页,共五十三页,编辑于2023年,星期六例11根据工作寄存器R0内容的不同,使程序转入相应的分支。(R0)=0对应的分支程序标号为PR0;(R0)=1对应的分支程序标号为PR1;(R0)=N对应的分支程序标号为PRN。…第二十页,共五十三页,编辑于2023年,星期六程序如下:LP0:MOVDPTR,#TAB;取表头地址MOVA,R0ADDA,R0;R0内容乘以2JNCLP1;无进位转移INCDPH;加进位位LP1:JMP@A+DPTR;跳至散转表中相应位置TAB:AJMPPR0AJMPPR1

AJMPPRn……第二十一页,共五十三页,编辑于2023年,星期六本例程序仅适用于散转表首地址TAB和处理程序入口地址PR0,PR1,…,PRn在同一个2KB范围的存储区内的情形。若超出2KB范围可在分支程序入口处安排一条长跳转指令,可采用如下程序:MOVDPTR,#TABMOVA,R0MOVB,#03H;长跳转指令占3个字节MULABXCHA,B第二十二页,共五十三页,编辑于2023年,星期六ADDA,DPHMOVDPH,AXCHA,BJMP@A+DPTR;跳至散转表中相应的位置TAB:LJMPPR0;跳至不同的分支LJMPPR1LJMPPRn……第二十三页,共五十三页,编辑于2023年,星期六4.2.3循环程序设计第二十四页,共五十三页,编辑于2023年,星期六循环程序一般由四个主要部分组成:(1)初始化部分:为循环程序做准备,如规定循环次数、给各变量和地址指针预置初值。(2)处理部分:为反复执行的程序段,是循环程序的实体,也是循环程序的主体。(3)循环控制部分:这部分的作用是修改循环变量和控制变量,并判断循环是否结束,直到符合结束条件时,跳出循环为止。(4)结束部分:这部分主要是对循环程序的结果进行分析、处理和存放。第二十五页,共五十三页,编辑于2023年,星期六

例5工作单元清零。在应用系统程序设计时,有时经常需要将存储器中各部分地址单元作为工作单元,存放程序执行的中间值或执行结果,工作单元清零工作常常放在程序的初始化部分中。设有50个工作单元,其首址为外部存储器8000H单元,则其工作单元清零程序如下:第二十六页,共五十三页,编辑于2023年,星期六CLEAR:CLRAMOVDPTR,#8000H;工作单元首址送指针MOVR2,50;置循环次数CLEAR1:MOVX@DPTR,AINCDPTR;修改指针DJNZR2,CLEAR1;控制循环RET第二十七页,共五十三页,编辑于2023年,星期六例6设在内部RAM的BLOCK单元开始处有长度为LEN个的无符号数据块,试编一个求和程序,并将和存入内部RAM的SUM单元(设和不超过8位)。BLOCKEQU20HLENEQU30HSUMEQU40HSTART:CLRA;清累加器AMOVR2,#LEN;数据块长度送R2MOVR1,#BLOCK;数据块首址送R1LOOP:ADDA,@R1;循环加法INCR1;修改地址指针DJNZR2,LOOP;修改计数器并判断MOVSUM,A;存和RET第二十八页,共五十三页,编辑于2023年,星期六多重循环例7、10秒延时程序。延时程序与执行指令的时间有关,如果使用6MHz晶振,一个机器周期为2μs,计算出一条指令以至一个循环所需要的执行时间,给出相应的循环次数,便能达到延时的目的。10秒延时程序如下:DELAY:MOVR5,#100DEL0:MOVR6,#200DEL1:MOVR7,#248DEL2:DJNZR7,DEL2DJNZR6,DEL1DJNZR5,DEL0RET第二十九页,共五十三页,编辑于2023年,星期六上例程序中采用了多重循环程序,即在一个循环体中又包含了其它的循环程序,这种方式是实现延时程序的常用方法。使用多重循环时,必须注意:(1)循环嵌套,须层次分明,不允许有内外层循环交叉。(2)外循环可一层层向内循环进入,结束时由里往外一层层退出。(3)内循环可以直接转入外循环,实现一个循环由多个条件控制的循环结构方式。第三十页,共五十三页,编辑于2023年,星期六

例10在内部RAM中从50H单元开始的连续单元依次存放了一串字符,该字符串以回车符为结束标志,要求测试该字符串的长度。程序如下:START:MOVR2,#0FFHMOVR0,#4FH;数据指针R0置初值LOOP:INCR0INCR2CJNE@R0,#0DH,LOOPRET第三十一页,共五十三页,编辑于2023年,星期六4.2.5子程序和参数传递

一、子程序的概念通常把这些基本操作功能编制为程序段作为独立的子程序,以供不同程序或同一程序反复调用。在程序中需要执行这种操作的地方放置一条调用指令,当程序执行到调用指令,就转到子程序中完成规定的操作,并返回到原来的程序继续执行下去。第三十二页,共五十三页,编辑于2023年,星期六二、子程序的调用调用子程序的指令有“ACALL”和“LCALL”,执行调用指令时,先将程序地址指针PC改变(“ACALL”加2,“LCALL”加3),然后PC值压入堆栈,用新的地址值代替。执行返回指令时,再将PC值弹出。子程序调用中,主程序应先把有关的参数存入约定的位置,子程序在执行时,可以从约定的位置取得参数,当子程序执行完,将得到的结果再存入约定的位置,返回主程序后,主程序可以从这些约定的位置上取得需要的结果,这就是参数的传递。第三十三页,共五十三页,编辑于2023年,星期六4.3.1查表程序设计查表程序是一种常用程序,它广泛使用于LED显示控制、打印机打印控制、数据补偿、数值计算、转换等功能程序中,这类程序具有简单、执行速度快等特点。所谓查表法,就是预先将满足一定精度要求的表示变量与函数值之间关系的一张表求出,然后把这张表存于单片机的程序存储器中,这时自变量值为单元地址,相应的函数值为该地址单元中的内容。查表,就是根据变量X在表格中查找对应的函数值Y,使Y=f(X)。第三十四页,共五十三页,编辑于2023年,星期六指令系统中,有两条查表指令:MOVCA,@A+PCMOVCA,@A+DPTR第三十五页,共五十三页,编辑于2023年,星期六例一个十六进制数存放在内部RAM的HEX单元的低4位中,将其转换成ASCII码并送回HEX单元。十六进制0~9的ASCII码为30H~39H,A~F的ASCII码为41H~46H,ASCII码表格的首地址为ASCTAB。编程如下: ORG1000HHEXASC: MOVA,HEX ANLA,#0FH ADDA,#3 ;修改指针 MOVCA,@A+PC MOVHEX,A RET第三十六页,共五十三页,编辑于2023年,星期六ASCTAB:DB30H,31H,32H,33H,34H DB35H,36H,37H,38H,39H DB41H,42H,43H,44H,45HDB46H在这个程序中,查表指令MOVCA,@A+PC到表格首地址有两条指令,占用3个字节地址空间,故修改指针应加3。第三十七页,共五十三页,编辑于2023年,星期六例设有一个巡回检测报警装置,需对96路输入进行控制,每路有一个额定的最大值,是双字节数。当检测量大于该路对应的最大值时,就越限报警。假设R2为保存检测路数的寄存器,其对应的最大额定值存放于31H和32H单元中。查找最大额定值的程序如下:FMAX:MOVA,R2 ADDA,R2;表中一个额定值为2个字节 MOV31H,A MOVDPTR,#TAB;表首址第三十八页,共五十三页,编辑于2023年,星期六 MOVCA,@A+DPTR;查表读取第一个字节 XCHA,31H;第一个字节内容存入31H INCDPTR MOVCA,@A+DPTR;查表读取第二个字节 MOV32H,A;第二字节的内容存入32HTAB:DW1230H,1450H,... DW2230H,2440H,... DW3120H,3300H,...第三十九页,共五十三页,编辑于2023年,星期六

例在一个温度检测系统中,温度模拟信号由10位A/D输入。将A/D结果转换为对应温度值,可采用查表方法实现。先由实验测试出整个温度量程范围内的A/D转换结果,把A/D转换结果000H~3FFH所对应的温度值组织为一个表存储在程序存储器中,那么就可以根据检测到的模拟量的A/D转换值查找出相应的温度值。设测得的A/D转换结果已存入20H,21H单元中(高字节在20H中,低字节在21H中),查表得到的温度值存放在22H,23H单元(高字节在22H中,低字节在23H中)。第四十页,共五十三页,编辑于2023年,星期六程序如下:FTMP:MOVDPTR,#TAB;DPTR←表首地址 MOVA,21H;(20H)(21H)×2 CLRC RLCA MOV21H,A MOVA,20H RLCA MOV20H,A MOVA,21H;表首地址+偏移量 ADDA,DPL MOVDPL,A第四十一页,共五十三页,编辑于2023年,星期六MOVA,20HADDCA,DPHMOVDPH,ACLRAMOVCA,@A+DPTR;查表得温度值高位字节MOV22H,ACLRAINCDPTRMOVCA,@A+DPTR;查表得温度值低位字节MOV23H,ARETTAB:DW…第四十二页,共五十三页,编辑于2023年,星期六4.3.2数制转换例将一个字节二进制数转换成3位非压缩型BCD码。设一个字节二进制数在内部RAM40H单元,转换结果放入内部RAM50H,51H,52H单元中(高位在前),程序如下:HEXBCD:MOVA,40HMOVB,#100DIVABMOV50H,AMOVA,#10XCHA,BDIVABMOV51H,AMOV52H,BRET第四十三页,共五十三页,编辑于2023年,星期六例设4位BCD码依次存放在内存RAM中40H~43H单元的低4位,高4位都为0,要求将其转换为二进制数,结果存入R2R3中。一个十进制数可表示为:Dn×10n+Dn-1×10n-1+…+D0×100=(…((Dn×10+Dn-1)×10+Dn-2)×10+…)+D0当n=3时,上式可表示为:((D3×10+D2)×10+D1)×10+D0

第四十四页,共五十三页,编辑于2023年,星期六BCDHEX:MOVR0,#40H;R0指向最高位地址MOVR1,#03;计数值送R1MOVR2,#0;存放结果的高位清零MOVA,@R0MOVR3,A;初始化LOOP:MOVA,R3MOVB,#10MULABMOVR3,A;(R3)×10的低8位送R3MOVA,BXCHA,R2;(R3)×10的高8位暂存R2MOVB,#10第四十五页,共五十三页,编辑于2023年,星期六MULABADDA,R2MOVR2,A;R2×10+(R3×10)高8位送R2INCR0;取下一个BCD数MOVA,R3;加低位ADDA,@R0MOVR3,AMOVA,R2;处理进位ADDCA,#0MOVR2,ADJNZR1,LOOPRET第四十六页,共五十三页,编辑于2023年,星期六例在外部RAM中,BLOCK开始的单元中有一无符号数据块,其个数为LEN个字节。试将这些无符号数按递减次序重新排列,并存入原存储区。ORG1000HSTART:MOVDPTR,#BLOCK;置地址指针MOVP2,DPH;P2作地址指针高字节MOVR7,#LEN;置外循环计数初值DECR7;比较与交换n-1次4.3.3数值处理(查找和排序)第四十七页,共五十三页,编辑于2023年,星期六LOOP0:

温馨提示

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

评论

0/150

提交评论