单片微型计算机原理及接口技术教学课件 第4章汇编语言程序设计

上传人:w****i 文档编号:94637225 上传时间:2019-08-09 格式:PPT 页数:41 大小:172.50KB
返回 下载 相关 举报
单片微型计算机原理及接口技术教学课件 第4章汇编语言程序设计_第1页
第1页 / 共41页
单片微型计算机原理及接口技术教学课件 第4章汇编语言程序设计_第2页
第2页 / 共41页
单片微型计算机原理及接口技术教学课件 第4章汇编语言程序设计_第3页
第3页 / 共41页
单片微型计算机原理及接口技术教学课件 第4章汇编语言程序设计_第4页
第4页 / 共41页
单片微型计算机原理及接口技术教学课件 第4章汇编语言程序设计_第5页
第5页 / 共41页
点击查看更多>>
资源描述

《单片微型计算机原理及接口技术教学课件 第4章汇编语言程序设计》由会员分享,可在线阅读,更多相关《单片微型计算机原理及接口技术教学课件 第4章汇编语言程序设计(41页珍藏版)》请在金锄头文库上搜索。

1、第4章 汇编语言程序设计,4.1 汇编语言基本概念 4.2 汇编语言程序设计,4.1 汇编语言基本概念,4.1.1 程序设计语言 4.1.2 汇编语言的语句结构 4.1.3 伪指令,返回本章首页,4.1.1 程序设计语言,按照语言的结构及其功能可以分为三种: 1机器语言:机器语言是用二进制代码0和1表示指令和数据的最原始的程序设计语言。 2汇编语言:在汇编语言中,指令用助记符表示,地址、操作数可用标号、符号地址及字符等形式来描述。 3高级语言:高级语言是接近于人的自然语言,面向过程而独立于机器的通用语言。,返回本节,4.1.2 汇编语言的语句结构,1汇编语言的指令类型 MCS-51单片机汇编语

2、言,包含两类不同性质的指令。 (1)基本指令:即指令系统中的指令。它们都是机器能够执行的指令,每一条指令都有对应的机器码。 (2)伪指令:汇编时用于控制汇编的指令。它们都是机器不执行的指令,无机器码。,2汇编语言的语句格式 汇编语言源程序是由汇编语句(即指令)组成的。汇编语言一般由四部分组成。 其典型的汇编语句格式如下: 标号: 操作码 操作数 ;注释 START: MOV A,30H ;A(30H),返回本节,4.1.3 伪指令,1ORG:汇编起始地址 用来说明以下程序段在存储器中存放的起始地址。 例如程序: ORG 1000H START: MOV A,#20H MOV B,#30H 2E

3、QU:赋值 给变量标号赋予一个确定的数值。,3DB:定义数据字节 把数据以字节数的形式存放在存储器单元中。 4DW:定义数据字 按字的形式把数据存放在存储单元中。 5DS:定义存储区 从指定的地址单元开始,保留一定数量存储单元。 6BIT:位定义 确定字符名为确定的位地址值。 7END:汇编结束,返回本节,4.2 汇编语言程序设计,4.2.1 汇编语方程序设计步骤 4.2.2 顺序程序 4.2.3 分支程序 4.2.4 循环程序 4.2.5 子程序 4.2.6 位操作程序,返回本章首页,4.2.1 汇编语方程序设计步骤,1分析问题 2确定算法 3设计程序流程图 4分配内存单元 5编写汇编语言源

4、程序 6调试程序,返回本节,4.2.2 顺序程序,顺序程序是一种最简单,最基本的程序。 特点:程序按编写的顺序依次往下执行每一条指令,直到最后一条。 【例4.1】 将30H单元内的两位BCD码拆开并转换成ASCII码,存入RAM两个单元中。程序流程如图4-1所示。参考程序如下: ORG 2000H MOV A,30H ;取值 ANL A,#0FH ;取低4位,ADD A,#30H ;转换成ASCII码 MOV 32H,A ;保存结果 MOV A,30H ;取值 SWAP A ;高4位与低4位互换 ANL A,#0FH ;取低4位(原来的高4位) ADD A,#30H ;转换成ASCII码 MO

5、V 31H,A ;保存结果 SJMP $ END,图4-1 拆字程序流程图,图4-2 例4.2程序流程图,【例4.2】 设X、Y两个小于10的整数分别存于片内30H、31H单元,试求两数的平方和并将结果存于32H单元。 解:两数均小于10,故两数的平方和小于100,可利用乘法指令求平方。程序流程如图4-2所示。参考程序如下: ORG 2000H MOV A,30H ;取30H单元数据 MOV B,A ;将X送入B寄存器,MUL AB ;求X2,结果在累加器中 MOV R1,A ;将结果暂存于R1寄存器中 MOV A,31H ;取31H单元数据 MOV B,A ;将Y送入B寄存器 MUL AB

6、;求Y2,结果在累加器中 ADD A,R1 ;求X2+ Y2 MOV 32H,A ;保存数据 SJMP $ ;暂停 END,图4-2 例4.2程序流程图,返回本节,4.2.3 分支程序,1分支程序的基本形式 分支程序有三种基本形式,如图4-3所示。 分支程序的设计要点如下: (1)先建立可供条件转移指令测试的条件。 (2)选用合适的条件转移指令。 (3)在转移的目的地址处设定标号。,图4-3 分支程序结构流程图,2双向分支程序设计举例 【例4.3】 设X存在30H单元中,根据下式 X+2 X0 Y = 100 X=0 求出Y值,将Y值存入31H单元。 X X0 解:根据数据的符号位判别该数的正

7、负,若最高位为0,再判别该数是否为0。程序流程如图4-4所示。 参考程序如下:ORG 1000H,MOV A,30H ;取数 JB ACC.7,NEG;负数,转NEG JZ ZER0 ;为零,转ZER0 ADD A,#02H ;为正数,求X+2 AJMP SAVE ;转到SAVE,保存数据 ZER0:MOV A,# 64H ;数据为零,Y=100 AJMP SAVE ;转到SAVE,保存数据 NEG:DEC A ; CPL A ;求X SAVE: MOV 31H,A ;保存数据 SJMP ;暂停,图4-4 例4.3程序流程图,3多向分支程序设计举例 【例4.4】 根据R0的值转向7个分支程序。

8、 R010,转向SUB0; R020,转向SUB1; R060,转向SUB5; R060,转向SUB6; 解:利用JMP A+DPTR 指令直接给PC赋值,使程序实现转移。程序流程如图4-5所示。,参考程序如下: ORG 2000H MOV DPTR,#TAB;转移指令表首地址 MOV A,R0 ;取数 MOV B,#10 DIV AB ;A10,商在A中 CLR C RLC A ;A2A JMP A+DPTR ;PC A+DPTR TAB: AJMP SUB0 ;转移指令表 AJMP SUB1 AJMP SUB2 AJMP SUB5 AJMP SUB6,图4-5 多向分支程序流程图,返回本节

9、,4.2.4 循环程序,1循环程序的结构(如图4-6所示) 循环程序一般包括如下四个部分: (1)初始化 (2)循环体 (3)循环控制 (4)结束 循环程序按结构形式,有单重循环与多重循环。 在多重循环中,只允许外重循环嵌套内重循环。 不允许循环相互交叉,也不允许从循环程序的外部跳入循环程序的内部(如图4-7所示)。,图4-6 循环结构程序流程图,图4-7 多重循环示意图,2循环程序设计举例 【例4.5】有一数据块从片内RAM的30H单元开始存入,设数据块长度为10个单元。根据下式: X+2 X0 Y= 100 X=0 求出Y值,并将Y值放回原处。 X X0 解:设置一个计数器控制循环次数,每

10、处理完一个数据,计数器减1。程序流程如图4-8所示。,参考源程序如下: ORG 2000H MOV R0,#10 MOV R1,#30H START: MOV A,R1 ;取数 JB ACC.7,NEG ;若为负数,转NEG JZ ZER0 ;若为零,转ZER0 ADD A,#02H ;若为正数,求X+2 AJMP SAVE ;转到SAVE,保存数据 ZER0: MOV A,# 64H ;数据为零,Y=100,AJMP SAVE ;转到SAVE,保存数据 NEG: DEC A CPL A ;求X SAVE: MOV R1,A ;保存数据 INC R1 ;地址指针指向下一个地址 DJNZ R0,

11、START ;数据未处理完,继续处理 SJMP ;暂停,图4-8 例4.5的程序流程图,返回本节,4.2.5 子程序,1子程序概念 所谓调用子程序,暂时中断主程序的执行,而转到子程序的入口地址去执行子程序。如图4-10所示。调用子程序应注意: (1)子程序占用的存储单元和寄存器。 (2)参数的传递。 (3)子程序经过调用后得到的数据来完成程序之间的参数传递。 (4)嵌套调用与递归调用。如图4-11所示。,图4-10 子程序的调用与返回,图4-11 子程序的嵌套调用与返回,2子程序设计举例 【例4.8】 将4.4节中的例4.5改为子程序结构。 解:数据块中的十个数都需要进行符号判断并作相应处理,

12、可把一部分工作交给子程序完成,主程序只负责读取数据、调用判断处理子程序、保存数据、循环控制工作。源程序如下: ORG 0000H MOV R0,#10 MOV R1,#30H,START: MOV A,R1 ;取数 ACALL DISPOSE ;调用判断、处理子程序 SAVE: MOV R1,A ;保存数据 INC R1 ;修改地址指针,指向下一个地址 DJNZ R0,START ;数据未处理完,继续处理 SJMP ;暂停 ORG 0200H DISPOSE: JB ACC.7,NEG ;若为负数,转NEG,JZ ZER0 ;若为零,转ZER0 ADD A,#02H ;若为正数,求X+2 AJ

13、MP BACK ;转到SAVE,保存数据 ZER0: MOV A,#64H ;数据为零,Y=100 AJMP BACK ;转到SAVE,保存数据 NEG: DEC A CPL A ;求X BACK: RET,返回本节,4.2.6 位操作程序,【例4.9】 编写一程序,实现图4-12中的逻辑运算电路。其中P3.1、P1.1、P1.0分别是单片机端口线上的信息,RS0、RS1是PSW寄存器中的两个标志位,30H、31H是两个位地址,运算结果由P1.0输出。 程序如下: ORG 0000H MOV C,P3.1,ANL C,P1.1 CPL C MOV 20H,C ;暂存数据 MOV C,30H ORL C,/31H ANL C,RS1 ANL C,20H ANL C,RS0 MOV P1.0,C ;输出结果 SJMP $,图4-12 硬件逻辑硬件电路图,返回本节,THANK YOU VERY MUCH !,本章到此结束, 谢谢您的光临!,结束放映,返回本章首页,

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 高等教育 > 大学课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号