ImageVerifierCode 换一换
格式:DOCX , 页数:23 ,大小:26.59KB ,
资源ID:27837578      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/27837578.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(第四章汇编语言程序设计基础.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

第四章汇编语言程序设计基础.docx

1、第四章汇编语言程序设计基础授课教师授课班级课的类型授课时间课时分配授课地点课题汇编语言程序设计基础教学目标1、数据传送类指令2、控制转移指令3、延时程序的概念和程序设计重点 2、数据传送类指令3、控制转移指令4、延时程序的概念和程序设计难点能够独立分析程序教法讲授法多媒体形式教具多媒体作业1.课堂作业教材P113页练习题2.课下作业打印片子一套引入课题:新课教学:汇编语言是面向机器硬件的语言,要求程序设计者对MCS-51单片机具有很好的“软、硬结合”的功底。 介绍程序设计的基本知识及如何使用汇编语言来进行基本的程序设计。4.1 汇编语言程序设计概述 4.1.1 机器语言、汇编语言和高级语言用于

2、程序设计的语言基本上分为3种:机器语言、汇编语言和高级语言。 1.机器语言 二进制代码表示的指令、数字和符号简称为机器语言 不易懂,难记忆,易出错。 2汇编语言 英文助记符表示的指令称为符号语言或汇编语言将汇编语言程序转换成为二进制代码表示的机器语言程序称为汇编程序经汇编程序“汇编(翻译)”得到的机器语言程序称为目标程序,原来的汇编语言程序称为源程序。汇编语言特点:面向机器的语言,程序设计员须对MCS-51的硬件有相当深入的了解。助记符指令和机器指令一一对应,用汇编语言编写的程序效率高,占用存储空间小,运行速度快,用汇编语言能编写出最优化的程序。 能直接管理和控制硬件设备(功能部件),它能处理

3、中断,也能直接访问存储器及I/O接口电路。汇编语言和机器语言都脱离不开具体机器的硬件,均是面向“机器”的语言,缺乏通用性。3高级语言不受具体机器的限制,使用了许多数学公式和数学计算上的习惯用语,非常擅长于科学计算。常用的如BASIC、FORTRAN以及C语言等。高级语言优点:通用性强,直观、易懂、易学,可读性好。使用C语言(C51)、PL/M语言来进行MCS-51的应用程序设计。 对于程序的空间和时间要求很高的场合,汇编语言仍是必不可缺的。 C语言和汇编语言混合编程 在很多需要直接控制硬件的应用场合,则更是非用汇编语言不可 使用汇编语言编程,是单片机程序设计的基本功之一4.1.2 汇编语言语句

4、的种类和格式两种基本类型:指令语句和伪指令语句(1)指令语句已在第3章介绍每一条指令语句在汇编时都产生一个指令代码机器代码(2)伪指令语句 是为汇编服务的。在汇编时没有机器代码与之对应。 MCS-51的汇编语言的四分段格式如下: 标号字段 操作码字段 操作数字段 注释字段规则:(1)标号字段和操作字码段之间要有冒号“:”相隔;(2)操作码字段和操作数字段间的分界符是空格;(3)双操作数之间用逗号相隔; (4)操作数字段和注释字段之间的分界符用分号“;”相隔。操作码字段为必选项,其余各段为任选项。例4-1 下面是一段汇编语言程序的四分段书写格式 标号字段 操作码字段 操作数字段 注释字段 STA

5、RT: MOV A,#00H ;0A MOV R1,#10 ;10R1 MOV R2,#00000011B ;3R2 LOOP:ADD A,R2 ;(A)+(R2)A DJNZ R1,LOOP;R1内容减1不 为零,则循环 NOP HERE: SJMP HERE基本语法规则:1标号字段是语句所在地址的标志符号 (1)标号后边必须跟以冒号“:” (2)由18个ASCII字符组成(3)同一标号在一个程序中只能定义一次 (4)不能使用汇编语言已经定义的符号作为标号 2操作码字段 是汇编语言指令中唯一不能空缺的部分。汇编程序就是根据这一字段来生成机器代码的。3操作数字段 通常有单操作数、双操作数和无操

6、作数三种情况。如果是双操作数,则操作数之间,要以逗号隔开。(1)十六进制、二进制和十进制形式的操作数表示 采用十六进制形式来表示 ,某些特殊场合才采用二进制或十进制的表示形式 。十六进制,后缀“H” 。二进制,后缀“B” 。十进制,后缀“D”,也可省略。若十六进制的操作数以字符AF中的某个开头时,则需在它前面加一个 “0”,以便在汇编时把它和字符AF区别开来。(2)工作寄存器和特殊功能寄存器的表示采用工作寄存器和特殊功能寄存器的代号来表示,也可用其地址来表示。 例如,累加器可用A(或Acc)表示。也可用0E0H来表示,0E0H为累加器A的地址。(3)美元符号$的使用用于表示该转移指令操作码所在

7、的地址。例如,如下指令: JNB F0, $与如下指令是等价的: HERE:JNB F0,HERE 再如: HERE:SJMP HERE可写为: SJMP $4注释字段 必须以分号“;”开头,换行书写,但必须注意也要以分号“;”开头。 汇编时,注释字段不会产生机器代码。4.1.3 伪指令在MCS-51 汇编语言源程序中应有向汇编程序发出的指示信息,告诉它如何完成汇编工作,这是通过使用伪指令来实现的。也称为汇编程序控制命令。只有在汇编前的源程序中才有伪指令。经过汇编得到目标程序(机器代码)后,伪指令已无存在的必要,所以“伪”体现在汇编时,伪指令没有相应的机器代码产生。常用的伪指令: 1.ORG(

8、ORiGin)汇编起始地址命令 在汇编语言源程序的开始,通常都用一条ORG伪指令来实现规定程序的起始地址。如不用ORG规定,则汇编得到的目标程序将从0000H开始。例如: ORG 2000HSTART: MOV A,#00H 规定标号START代表地址为2000H开始。在一个源程序中,可多次使用ORG指令,来规定不同的程序段的起始地址。但是,地址必须由小到大排列,地址不能交叉、重叠。例如: ORG 2000H ORG 2500H ORG 3000H 2. END(END of assembly)汇编终止命令汇编语言源程序的结束标志,用于终止源程序的汇编工作。在整个源程序中只能有一条END命令,

9、且位于程序的最后。3DB(Define Byte)定义字节命令在程序存储器的连续单元中定义字节数据。 ORG 2000HDB 30H,40H,24,“C”,“B”汇编后: (2000H)=30H (2001H)=40H (2002H)=18H(10进制数24) (2003H)=43H(字符“C”的ASCII码) (2004H)=42H(字符“B”的ASCII码)DB功能是从指定单元开始定义(存储)若干个字节,10进制数自然转换成16进制数,字母按ASCII码存储。4DW(Define Word)定义数据字命令从指定的地址开始,在程序存储器的连续单元中定义16位的数据字。例如: ORG 2000

10、H DW 1246H,7BH,10汇编后:(2000H)=12H ;第1个字(2001H)=46H (2002H)=00H ;第2个字(2003H)=7BH(2004H)=00H ;第3个字(2005H)=0AH(2005H)=0AH 5EQU(EQUate)赋值命令用于给标号赋值。赋值以后,其标号值在整个程序有效。例如:TEST EQU 2000H 表示标号TEST=2000H,在汇编时,凡是遇到标号TEST时,均以2000H来代替。 4.1.4 汇编语言程序设计步骤(1)分析问题,确定算法(2)根据算法,画出程序框图(3)分配内存工作区及有关端口地址(4)编写程序养成在程序的适当位置上加上

11、注释的好习惯。(5)上机调试编写完毕的程序,必须“汇编”成机器代码,才能调试和运行,调试与硬件有关程序还要借助于仿真开发工具并与硬件连接。4.2 汇编语言源程序的汇编汇编语言源程序 “翻译”成机器代码(指令代码)的过程称为“汇编”。汇编可分为手工汇编和机器汇编两类:4.2.1 手工汇编人工查表翻译指令。但遇到的相对转移指令的偏移量的计算,要根据转移的目标地址计算偏移量,不但麻烦,且容易出错。4.2.2 机器汇编用编辑软件进行源程序的编辑。编辑完成后,生成一个ASCII码文件,扩展名为“.ASM”。然后在微计算机上运行汇编程序,把汇编语言源程序翻译成机器代码。交叉汇编汇编后的机器代码是在另一台计

12、算机(这里是单片机)上运行。 MCS-51单片机的应用程序的完成,应经过三个步骤;(1)在微计算机上,运行编辑程序进行源程序的输入 和编辑; (2)对源程序进行交叉汇编得到机器代码;(3)通过微计算机的串行口(或并行口)把机器代码传送到用户样机(或在线仿真器)进行程序的调试和运行。第(1)步,只需在微计算机上使用通用的编辑软件即可完成。第(2)步的交叉汇编所用的汇编程序可在购买单片机的仿真开发工具时,由厂商提供。第(3)步骤的实现要借助于单片机仿真开发工具进行。反汇编分析现成产品的程序,要将二进制的机器代码语言程序翻译成汇编语言源程序。例4-2 下面是一段源程序的汇编结果,读者可通过查第3章的

13、表3-3至表3-7 ,进行手工汇编,来验证下面的汇编结果是否正确。 见表4-1(P75) 4.3 汇编语言实用程序设计 4.3.1 汇编语言程序的基本结构形式常 顺采用以下几种基本结构:序结构、分支结构和循环结构,再加上广泛使用的子程序和中断服务子程序。 1顺序结构 2分支结构 程序中含有转移指令, 无条件分支,有条件分支。 有条件分支又分为:单分支结构和多分支结构。 3循环结构 4子程序 5中断服务子程序4.3.2 子程序的设计一、子程序设计原则和应注意的问题 一种能完成某一特定任务的程序段。其资源要为所有调用程序共享。因此,子程序在结构上应具有独立性和通用性,在编写子程序时应注意以下问题:

14、 1子程序的第一条指令的地址称为子程序的入口地址。该指令前必须有标号。 2主程序调用子程序 两条子程序调用指令: (1)绝对调用指令:ACALL addr11 (2)长调用指令:LCALL addr163注意设置堆栈指针和现场保护4最后一条指令必须是RET指令5子程序可以嵌套,即子程序可以调用子程序6在子程序调用时,还要注意参数传递的问题 二、 子程序的基本结构 MAIN: ;MAIN为主程序或调用程序标号 LCALL SUB ;调用子程序SUB SUB:PUSH PSW ;现场保护 PUSH ACC ; 子程序处理程序段 POP ACC ;现场恢复 POP PSW ; RET ;最后一条指令

15、必须为RET例4-3 单字节有符号数的加减法子程序(自己阅读) 本例中参数传递是通过累加器A完成的,主程序将被转换的数送到A中,子程序将A中的有符号数求补后存于A中,主程序再将结果放回原来的单元。 例4-4 4位BCD码的减法程序(自己阅读) 主程序通过地址寄存器R0和R1将参加运算的BCD码的地址传递给子程序,子程序则通过累加器将差传递给主程序。4.3.3 查表程序设计 数据补偿、修正、计算、转换等各种功能,具有程序简单、执行速度快等优点。查表就是根据自变量x,在表格中寻找y,使y=f(x)。执行查表指令时,发出读程序存储器选通脉冲/PSEN。在MCS-51的指令系统中,给用户提供了两条极为

16、有用的查表指令: MOVC A,A+DPTR MOVC A,A+PC指令“MOVC A,A+DPTR”完成把A中的内容作为一个无符号数与DPTR中的内容相加,所得结果为某一程序存储单元的地址,然后把该地址单元中的内容送到累加器A中。指令“MOVC A,A+PC”以PC作为基址寄存器,PC的内容和A的内容作为无符号数,相加后所得的数作为某一程序存储器单元的地址,根据地址取出程序存储器相应单元中的内容送到累加器A中。指令执行完,PC的内容不发生变化,仍指向查表指令的下一条指令。优点在于预处理较少且不影响其它特殊功能寄存器的值,所以不必保护其它特殊功能寄存器的原先值。缺点在于该表格只能存放在这条指令

17、的地址X3X2X1X0以下的00FFH之中。表格所在的程序空间受到了限制。例4-5 子程序的功能为:根据累加器A中的数x(09之间)查x的平方表y,根据x的值查出相应的平方y。x和y均为单字节数。地 址 子程序 Y3Y2Y1Y0 ADD A,#01H Y3Y2Y1Y0+2 MOVC A,A+PC Y3Y2Y1Y0+3 RET Y3Y2Y1Y0+4 DB 00H,01H,04H,09H,10H DB 19H,24H,31H,40H,51H第1条指令 ADD A,#01H 的作用是加上偏移量,可以根据A的内容查出X对应的平方。 MOVC A,+DPTR 这条指令的应用范围较为广泛,一般情况下,大多

18、使用该指令,使用该指令时不必计算偏移量,使用该指令的优点是表格可以设在64K程序存储器空间内的任何地方,而不像 MOVC A,A+PC那样只设在PC下面的256个单元中,使用较方便。 上面的程序可改成如下形式: PUSH DPH ;保存DPH PUSH DPL ;保存DPL MOV DPTR,#TAB1 MOVC A,A+DPTR POP DPL ;恢复DPL POP DPH ;恢复DPH RETTAB1: DB 00H,01H,04H,09H,10H DB 19H,24H,31H,40H,51H例4-6 在一个以MCS-51为核心的温度控制器中,温度传感器输出的电压与温度为非线性关系,传感器

19、输出的电压已由A/D转换为10位二进制数。根据测得的不同温度下的电压值数据构成一个表,表中放温度 值y,x为电压值数据。设测得的电压值x放入R2R3中,根据电压值x,查找对应的温度值y,仍放入R2R3中。本例的x和y均为双字节无符号数。程序如下: LTB2:MOV DPTR,#TAB2 MOV A,R3 CLR C RLC A MOV R3,A XCH A,R2 RLC A XCH R2,A ADD A,DPL ;(R2R3)+(DPTR) (DPTR) MOV DPL,A MOV A,DPH ADDC A,R2 MOV DPH,A CLR A MOVC A,A+DPTR ;查第一字节 MOV

20、 R2,A ;第一字节存入R2中 CLR A INC DPTR MOVC A,A+DPTR ;查第二字节 MOV R3,A ;第二字节存入R3中 RET TAB2:DW ;温度值表例4-7 设有一个巡回检测报警装置,需对16路输入进行检测,每路有一最大允许值,为双字节数。运行时,需根据测量的路数,找出每路的最大允许值。看输入值是否大于最大允许值,如大于就报警。根据上述要求,编一个查表程序。 取路数为x(0x15),y为最大允许值,放在表格中。设进入查表程序前,路数x已放于R2中,查表后最大值y放于R3R4中。本例中的x为单字节数,y为双字节数。查表程序如下: TB3: MOV A,R2 ADD

21、 A,R2 ;(R2)*2(A) MOV R3,A ;保存指针 ADD A,#6 ;加偏移量 MOVC A,A+PC ;查第一字节 XCH A,R3 ADD A,#3 MOVC A,A+PC ;查第二字节 MOV R4,A RET TAB3: DW 1520,3721,42645,7580 ;最大值 ;表 DW 3483,32657,883,9943 DW 10000,40511,6758,8931 DW 4468,5871,13284,27808表格长度不能超过256个字节,且表格只能存放于MOVC A,A+PC指令以下的256个单元中。4.3.4 关键字查找程序设计顺序检索和对分检索一、顺

22、序检索 从第1项开始逐项顺序查找,判断所取数据是否与关键字相等。例4-8 从50个字节的无序表中查找一个关键字”H。 ORG 1000H MOV 30H,#H;关键字H送30H单元 MOV R1,#50 ;查找次数送R1 MOV A,#14 ;修正值送A MOV DPTR,#TAB4 ;表首地址送DPTRLOOP:PUSH ACC MOVC A, A+PC ;查表结果送A CJNE A,40H,LOOP1;(40H)不等于关键 字则转LOOP1 MOV R2,DPH ;已查到关键字,把该字 ;的地址送R2,R3 MOV R3,DPL ;DONE:RETLOOP1:POP ACC ;修正值弹出

23、INC A ;A+1A INC DPTR ;修改数据指针DPTR DJNZ R1,LOOP ;R10,未查完,继续查找 MOV R2,#00H ;R1=0,清“0” R2 和R3 MOV R3,#00H ;表中50个数已查完 AJMP DONE ;从子程序返回TAB4:DB , ;50个无序数据表二、对分检索前提:检索的数据表已经排好序,如何进行数据的排序,将在本节稍后介绍。方法:取数据表中间位置的数与关键字进行比较,如相等,则查找到;如果所取的数大于关键字,则下次对分检索的范围是从数据区起点到本次取数。如果取数小于关键字,则下次对分检索的范围是从本次取数数据区起点到数据区终点。依此类推,逐渐

24、缩小检索范围,减少次数,大大提高了查找速度。4.3.5 数据极值查找程序设计在指定的数据区中找出最大值(或最小值)。进行数值大小的比较,从这批数据中找出最大值(或最小值)并存于某一单元中。例4-9 片内RAM中存放一批数据,查找出最大值并存放于首地址中。设R0中存首地址,R2中存放字节数,程序框图如图4-1所示。程序如下: MOV R2,n ;n为要比较的数据字节数 MOV A,R0 ;存首地址指针 MOV R1,A DEC R2 ; MOV A,R1 LOOP: MOV R3, A DEC R1 CLR C SUBB A,R1 ;两个数比较 JNC LOOP1 ;C=0,A中的数大,跳LOO

25、P1 MOV A,R1 ;C=1,则大数送A SJMP LOOP2LOOP1:MOV A,R3 LOOP2:DJNZ R2, LOOP ;是否比较结束? MOV R0, A ;存最大数 RET 4.3.6 数据排序程序设计升序排,降序排。仅介绍无符号数据升序排。冒泡法:相邻数互换的排序方法,类似水中气泡上浮 。排序时从前向后进行相邻两个数的比较,次序与要求的顺序不符时,就将两个数互换;顺序符合要求不互换。 假设有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

26、 ;逆序,互换 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 ;逆序,互换,第一次冒 泡结束如此进行,各次冒泡的结果如下:第1次冒泡结果:4、1、2、5、6、3、7第2次冒泡结果:1、2、4、5、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)次就已完成排序 。如何判定排序是否已完成,

27、看各次冒泡中是否有互换发生,如果有数据互换,则排序还没完成。在程序设计中,常使用设置互换标志的方法,该标志的状态表示在一次冒泡中是否有互换进行。例4-10 一批单字节无符号数,以R0为首地址指针,R2中为字节数,将这批数进行升序排列。程序框图如图4-2所示。SORT: MOV A,R0 ; MOV R1, A MOV A,R2 ;字节数送入R5 MOV R5, A CLR F0 ;互换标志位F0清零 DEC R5 ; MOV A,R1 ; LOOP: MOV R3, A ; INC R1 ; CLR C ; MOV A,R1 ;比较大小 SUBB A,R3 ; JNC LOOP1 ; SETB F0 ;互换标志位F0置1 MOV A,R3; ; XCH A,R1 ;两个数互换 DEC R1 ; XCH A,R1 ; INC R1 LOOP1: MOV A,R1 DJNZ R5,LOOP JB F0,SORT RET备注

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1