版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、汇编语言设计,顺序结构分支结构循环结构,3.1汇编语言程序设计方法,汇编语言程序设计同高级语言程序设计一样,是有章可循的,只要按照一定的方法步骤去做,程序设计就会变成一件轻松愉快的事情,设计的程序也会规范、清晰、易读、易懂。使用汇编语言设计程序大致上可分为以下几个步骤。1.分析题意,明确要求。2.确定算法。3.画程序流程图。4.分配内存工作单元。5.编写源程序。6.程序优化。7.上机调试。,3.2顺序程序设计,【例】程序初始化。初始化就是为变量、寄存器、存储单元赋一初值,是最简单、最常用的操作。如将r0-r3,p1,30h,40h单元初始化为00h,把r4,r5初始化为0ffh。参考程序如下:
2、org0000h;pc起始地址ljmpstart;转主程序org0100h;主程序起始地址start:movr0,#00h;初始化movr1,#00hmovr2,#00hmovr3,#00hmovp1,#00h,movr4,#0ffhmovr5,#0ffhmov30h,#00hmov40h,#00hhere:sjmphere;反复执行该指令,相当于等待end用立即数比较直观,但用mova,#00h,movr0,a指令赋值,效果更好。,【例】逻辑运算。逻辑操作是控制过程中经常使用的,掌握逻辑运算的特点是提高程序效率的重要途径。在逻辑运算中,进位标标志cy的地位很特殊,它是逻辑累加器,大多数逻辑操
3、作要通过cy来完成。用程序实现图4-2所示的逻辑电路功能。,图3-2逻辑电路,参考程序如下:org0000hljmpstartorg0100hmovp1,#0ffh;p1口初始化loop:movc,p1.1orlc,p1.2;p1.1与p1.2逻辑或运算cplc;取反anlc,p1.0;c与p1.0逻辑与运算cplcmov07h,c;暂存于07h单元中movc,p1.3anlc,/p1.4;p1.3与p1.4的反逻辑与运算cplcorlc,07hmovp1.5,c;把结果在p1.5口输出sjmp$end,3.3分支程序设计,分支程序的主要特点是程序包含有判断环节,不同的条件对应不同的执行路径。
4、编程的关键任务是合理选用具有逻辑判断功能的指令。由于选择结构程序的走向不再是单一的,因此,在程序设计时,应该借助程序框图(判断框)来明确程序的走向,避免犯逻辑错误。一般情况下,每个选择分支均需单独一段程序,并有特定的名字,以便当条件满足时实现转移。1单分支选择结构当程序的判断是二选一时,称为单分支选择结构。通常用条件转移指令实现判断及转移。单分支选择结构有三种典型表现形式。,图3-3单分支选择结构,(a)当条件满足时执行分支程序1,否则执行分支程序2。(b)当条件满足时跳过程序段1,从程序段2顺序执行;否则,顺序执行程序段1和程序段2。(c)当条件满足时程序顺序执行程序段2;否则,重复执行程序
5、段1,直到条件满足为止。由于条件转移指令均属相对寻址方式,其相对偏移量rel是个带符号的8位二进制数,可正可负。因此,它可向高地址方向转移,也可向低地址方向转移。对于第三种形式,可用程序段1重复执行的次数作为判断条件,当重复次数达到某一数值时,停止重复,程序顺序往下执行。这是分支结构的一种特殊情况,这实际是循环结构程序。用这种方式可方便实现状态检测。【例】:loop:jbp1.1,loop单分支程序一般要使用状态标志,应注意标志位的建立。,【例】设a存放在累加器a中,b存放在寄存器b中,若a0,y=ab;若a0,则y=ab。这里的关键是判a是正数,还是负数;可通过判断acc.7确定。org00
6、00hljmpbrorg0100hbr:jbacc.7,minus;负数,转到minusclrc;清进位位subba,b;a-bsjmpdoneminus:adda,b;a+bdone:sjmp$;等待end,2双向分支程序设计举例【例4.3】设x存在30h单元中,根据下式x+2x0y=100x=0xx0求出y值,将y值存入31h单元。解:根据数据的符号位判别该数的正负,若最高位为0,再判别该数是否为0。程序流程如图4-4所示。,参考程序如下:org1000hmova,30h;取数jbacc.7,neg;负数,转negjzzer0;为零,转zer0adda,#02h;为正数,求x+2ajmps
7、ave;转到save,保存数据zer0:mova,#64h;数据为零,y=100ajmpsave;转到save,保存数据neg:decacpla;求xsave:mov31h,a;保存数据sjmp;暂停,2多分支选择结构当程序的判别输出有两个以上的出口流向时,称为多分支选择结构。8051的多分支结构程序还允许嵌套,即分支程序中又有另一个分支程序。汇编语言本身并不限制这种嵌套的层次数,但过多的嵌套层次将使程序的结构变得十分复杂和臃肿,以致造成逻辑上的混乱。多分支选择结构通常有两种形式,如图4-4所示。,图4-4多分支选择结构,8051的散转指令和比较指令均可以实现多分支转移。散转指令jmpa+dp
8、tr比较指令cjnea,direct,rel(共有4条)使用散转指令前,先将各分支程序编写好,存放在程序存储器中,并将各分支程序的入口地址组成一个表格放在一起,把表首地址送入dptr,把子程序的序号放入a中。在8051指令中,还有4条功能极强的比较转移指令:cjnea,direct,relcjnea,#data,relcjnern,#data,relcjneri,#data,rel这4条指令对指定单元内容进行比较,当不相等时程序作相对转移,并指出其大小,以备作第二次判断;若两者相等,则程序顺序执行。,【例】散转程序。编写程序,根据20h单元中的内容转入相应的分支,执行指定的操作,将结果存入指定
9、存储器单元。程序流程框图如图4-5所示,图3-5散转程序流程,参考程序org0000hljmpmemsresultequ0050horg0100hmems:mova,20hmovdptr,#kkkk;散转程序入口地址表首址rla;分支号乘2,每个入口地址均为2字节jmpa+dptr;转移end1:sjmp$kkkk:ajmpmemsp0;a=0加法ajmpmemsp1;a=1减法ajmpmemsp2;a=2乘法sjmpmemsp3;a=3除法sjmpmemsp4;a=4逻辑与sjmpmemsp5;a=5逻辑或,memsp0:mova,r0;相加分支clrcadda,r1movresult,al
10、jmpend1memsp1:mova,r0;相减分支clrcsubba,r1movresult,aljmpend1memsp2:mova,r0;乘法分支movb,r1clrcmulabmovresult,amovresult+1,bljmpend1,memsp3:mova,r0;除法分支movb,r1clrcdivabmovresult,amovresult+1,bljmpend1memsp4:mova,r0;逻辑与分支anla,r1movresult,aljmpend1memsp5:mova,r0;逻辑或分支orla,r1movresult,aljmpend1end,【例】两个无符号数比较大
11、小。设外部ram单元st1和st2中存放两个无符号二进制数,要找出其中的大数存入st3单元中。程序流程框图如图3-6所示。,图3-6求大数程序流程,参考程序如下:org0000hljmpstartorg0100hstart:mova,addr1;将addr1中内容送acjnea,addr2,loop1;两数比较,不相等则转loop1loop3:ajmp$;结束loop1:jcloop2;当cy1,转loop2movaddr3,a;cy0,(a)(addr2)sjmploop3;转结束loop2:movaddr3,addr2;cy1,(addr2)(a)sjmploop3end,3.4循环程序设
12、计,在实际应用中经常会遇到功能相同,需要多次重复执行某段程序的情况,这时可把这段程序设计成循环结构,这有助于节省程序的存储空间,提高程序的质量。循环程序一般由4部分组成。1.初始化。即设置循环过程中有关工作单元的初始值,如置循环次数、地址指针及工作单元清零等。2.循环体。即循环处理部分,完成主要的计算或操作任务,是重复执行的程序段。3.循环控制。每循环一次,就要修改循环次数、数据及地址指针等循环变量。并根据循环结束条件,判断是否结束循环。4.循环结束处理。对结果进行分析、处理、保存。,循环程序结构有两种,如图3-7所示。,图3-7循环程序结构,图(a)是“先执行后判断”结构,适用于循环次数已知
13、的情况。其特点是进入循环后,先执行循环处理部分,然后根据循环次数判断是否结束循环。图(b)是“先判断后执行”结构,适用于循环次数未知的情况。其特点是将循环控制部分放在循环的入口处,先根据循环控制条件判断是否结束循环,若不结束,则执行循环操作;若结束,则退出循环。,【例】50ms软件延时程序。软件延时程序一般都是由djnzrn,rel指令构成。执行一条djnz指令需要两个机器周期。软件延时程序的延时时间主要与机器周期和延时程序中的循环次数有关,在使用12mhz晶振时,一个机器周期为1s,执行一条djnz指令需要两个机器周期,即2s。适当设置循环次数,即可实现延时功能。参考程序如下:org0000
14、hljmpmemsorg0100hmems:del:movr7,#125;外循环次数,该指令为一个机器周期del1:movr6,#200;内循环次数del2:djnzr6,del2;2002400s(内循环时间)djnzr7,del1;0.4ms12550ms(外循环时间)sjmp$end,例2循环程序设计举例【例】有一数据块从片内ram的30h单元开始存入,设数据块长度为10个单元。根据下式:x+2x0y=100x=0求出y值,并将y值放回原处。xx0解:设置一个计数器控制循环次数,每处理完一个数据,计数器减1。程序流程如图4-8所示。,图4-8例4.5的程序流程图,返回本节,参考源程序如下
15、:org2000hmovr0,#10movr1,#30hstart:mova,r1;取数jbacc.7,neg;若为负数,转negjzzer0;若为零,转zer0adda,#02h;若为正数,求x+2ajmpsave;转到save,保存数据zer0:mova,#64h;数据为零,y=100,ajmpsave;转到save,保存数据neg:decacpla;求xsave:movr1,a;保存数据incr1;地址指针指向下一个地址djnzr0,start;数据未处理完,继续处理sjmp;暂停,【例】排序程序。设在内部ram中存一无符号数的数组,其长度为n,起始地址是30h,要求将它们按从大到小排序
16、,排序后仍存放在原区域中。按“冒泡法”对n个数排序时,可能用不到n-1次循环,排序就结束了。为了提高排序速度,程序中可设一交换标志位,如10h位,每次循环中,若有交换则执行setb10h,表明排序未完成;若无交换,则执行clr10h,表明排序已经完成。每次循环结束时,测10h位,判断排序是否结束。参考程序如下:org0000hljmpbubbleorg0100hbubble:movr0,#30hmovb,#64hclr10hdecb;长度计数,loop:mova,r0;内循环的入口mov20h,a;暂存,为交换作准备incr0mov21h,r0cjnea,21h,bueu;若(20h)(21h
17、)转移bueu:jncbunext;(20h)(21h)转移mova,r0;若(20h)(21h)则交换movr0,20hdecr0;使r0退格指向小地址movr0,aincr0;恢复r0指向大地址setb10h;置交换标志bunext:djnzb,loop;内循环是否结束的判断jb10h,bubble;判断标志位为1否?外循环结束的判断end,3.5子程序设计,在实际应用中,一些特定的运算或操作经常使用,例如多字节的加、减、乘、除处理,代码转换、字符处理等。如果每次遇到这些运算或操作,都重复编写程序,不仅会使程序烦琐冗长,而且也会浪费编程者大量时间。因此经常把这些功能模块按一定结构编写成固定
18、的程序段,存放在内存中,当需要时,调用这些程序段。通常将这种能够完成一定功能、可以被其它程序调用的程序段称为子程序。调用子程序的程序称为主程序或调用程序。调用子程序的过程,称为子程序调用,用acalladdr11和lcalladdr16两条指令完成。子程序执行完后返回主程序的过程称为子程序返回,用ret指令完成。,1.在编写子程序时要注意以下几点:要给每个子程序赋一个名字。它是子程序入口地址的符号,便于调用。明确入口参数、出口参数。所谓入口参数,即调用该子程序时应给哪些变量传递数值,放在哪个寄存器或哪个内存单元,通常称为参数传递。出口参数则表明了子程序执行的结果存在何处。例如,调用开平方子程序
19、,计算。在调用子程序之前,必须先将x值送到主程序与子程序的某一交接处n(如累加器a),调用子程序后,子程序从该交接处取得被开方数,并进行开方计算,求出的值。在返回主程序之前,子程序还必须把计算结果送到另一交接处m。这样在返回主程序之后,主程序才可能从交接处m得到的值。注意保护现场和恢复现场。在执行子程序时,可能要使用累加器、psw或某些工作寄存器,而在调用子程序之前,这些寄存器中可能存放有主程序的中间结果,这些中间结果在主程序中仍然有用,这就要求在子程序使用这些资源之前,要将其中的内容保护起来,即保护现场。当子程序执行完毕,即将返回主程序之前,再将这些内容取出,恢复到原来的寄存器,这一过程称为
20、恢复现场。,保护现场通常用堆栈来完成。并在子程序的开始部分使用压栈指令push,把需要保护的寄存器内容压入堆栈。当子程序执行结束,在返回指令ret前边使用弹栈指令pop,把堆栈中保护的内容弹出到原来的寄存器。要注意,由于堆栈操作是“先入后出”。因此,先压入堆栈的参数应该后弹出,才能保证恢复原来的数据。为了做到子程序有一定的通用性,子程序中的操作对象,尽量用地址或寄存器形式,而不用立即数、绝对地址形式。另外,子程序中如含有转移指令,应尽量用相对转移指令。2.子程序的调用与返回主程序调用子程序是通过子程序调用指令lcalladd16和acalladd11来实现的。前者称为长调用指令,指令的操作数部
21、分给出了子程序的16位入口地址;后者为绝对调用指令,它的操作数提供了子程序的11位入口地位,此地址与程序计数器pc的高5位并在一起,构成16位的调用地址(即子程序入口地址)。它们的功能,首先是将pc中的当前值(调用指令下一条指令地址,称断点地址)压入堆栈(即保护断点),然后将子程序入口地址送入pc,使程序转入子程序运行。,子程序的返回是通过返回指令ret实现的。这条指令的功能是将堆栈中返回地址(即断点)弹出堆栈,送回到pc,使程序返回到主程序断点处继续往下执行。子程序调用过程如图3-8所示,图3-8子程序调用过程,主程序在调用子程序时要注意以下问题。在主程序中,要安排相应指令来传递子程序的入口
22、参数,即提供子程序的入口数据。在主程序中,要安排相应的指令,处理子程序提供的出口数据,即操作结果。在主程序中,不希望被子程序更改内容的寄存器,也可以在调用前由主程序安排压栈指令来保护现场,子程序返回后再安排弹栈指令恢复现场。在主程序中,要正确地设置堆栈指针。,3.子程序嵌套子程序嵌套是指在子程序执行过程中,还可以调用另一个子程序。子程序嵌套过程如图3-9所示。,图3-9子程序嵌套过程,4.子程序的特性编写子程序应注意以下问题:通用性。为使子程序能适应各种不同程序、不同条件的调用,子程序应具有较好的通用性。可浮动性。可浮动性是指子程序段可设置在存储器的任何地址区域。假如子程序只能设置在固定的存储
23、器地址段,这在编制主程序时要特别注意存储器地址空间的分配,防止两者重叠。为了能使子程序段浮动,必须在子程序中避免选用绝对转移地址,而应选用相对转移类指令,子程序首地址亦应采用符号地址。可递归和可重入性。子程序能自己调用自己的性质,称为子程序的可递归性,而子程序能同时被多个任务(或多个用户程序)调用的性质,称为子程序的可重入性。这在比较复杂的程序中经常用到。子程序说明文件。对于通用子程序,为便于各种用户选用,要求在子程序编制完成后提供一个说明文件,使用户不必详读源程序,只需阅读说明文件就能了解子程序的功能及应用。,【例】求平方。用程序实现ca*ab*b。设a、b均小于10,a存在31h单元,b存
24、在32h单元,把c存入33h单元。因本题两次用到平方值,所以在程序中采用把求平方编为子程序的方法。子程序名称:sqr。功能:求x2,通过查平方表来获得。入口参数:某数在a中。出口参数:某数的平方在a中。参考主程序和子程序如下:主程序:org0000hljmpmainorg0100hmain:movsp,#3fh;设堆栈指针(调用和返回指令要用到堆栈)mova,31h;取a值lcallsqr;第一次调用,求a2movr1,a;a2值暂存r1中mova,32h;取b值lcallsqr;第二次调用,求b2adda,r1;完成a2b2mov33h,a;存结果到33hsjmp$;暂停,子程序:org02
25、00hsqr:adda,#01h;查表位置调整,ret为一字节指令movca,a+pc;查表取平方值ret;子程序返回tab:db0,1,4,9,16,25db36,49,64,81end求平方的子程序在此采用的是查表法,用伪指令db将09的平方值以表格的形式定义到rom中。子程序中a之所以要加1,是因为ret指令占了一个字节。,实践题目:十字路口交通灯要求:通过单片机的p1口控制实验仪上6个led按照交通灯的变化规律循环发光,模拟十字路口交通灯。实验电路如下,l5、l4、l3模拟东西方向交通灯,l2、l1、l0模拟南北方向交通灯。通过一条setb指令,可使某一灯亮,通过一条clr指令,可使某一灯灭。硬件:画出硬件电路原理图。软件:画出程序流程图,编写源程序。调试:记录调试过程,分析调试结果。,南北方向绿灯亮:东西方向红灯亮南北方向绿灯闪:东西方向红灯亮南北方向黄灯亮:东西方向红灯亮南北方向红灯亮:东西方向绿灯亮南北方向红灯亮:东西方向绿灯闪南北方向红灯亮:东西方向黄灯亮,srequp1.0;南北红灯syequp1.1;南北黄灯sgequp1.2;南北绿灯erequp1.3;东西红
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年录音棚短期租赁协议
- 2024年建筑工程钢筋供应与施工承包协议
- 2024年式轻型车辆租赁合同
- 宾馆年度工作总结5篇
- 2024年房产交易市场住宅买卖合同
- 2024医院信息化建设项目实施与维护合同
- 物业公司工作总结怎么写
- 2024年技术转让合同:新能源技术转让
- 2024年新式合作共赢:场地租赁协议
- 2024年新式雇佣协议
- GA 1809-2022城市供水系统反恐怖防范要求
- 幼儿园绘本故事:《老虎拔牙》 课件
- 2021年上半年《系统集成项目管理工程师》真题
- 一个冬天的童话 遇罗锦
- GB/T 706-2008热轧型钢
- 实验六 双子叶植物茎的初生结构和单子叶植物茎的结构
- GB/T 25032-2010生活垃圾焚烧炉渣集料
- GB/T 13610-2020天然气的组成分析气相色谱法
- 《彩虹》教案 省赛一等奖
- 2023年湖南建筑工程初中级职称考试基础知识
- 沈阳机场航站楼扩建工程安装施工组织设计
评论
0/150
提交评论