MCS-51单片机 第4章 汇编语言程序设计.ppt

MCS-51单片机 第4章 汇编语言程序设计.ppt

ID:55829339

大小:128.50 KB

页数:41页

时间:2020-06-09

MCS-51单片机 第4章  汇编语言程序设计.ppt_第1页
MCS-51单片机 第4章  汇编语言程序设计.ppt_第2页
MCS-51单片机 第4章  汇编语言程序设计.ppt_第3页
MCS-51单片机 第4章  汇编语言程序设计.ppt_第4页
MCS-51单片机 第4章  汇编语言程序设计.ppt_第5页
资源描述:

《MCS-51单片机 第4章 汇编语言程序设计.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

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:MOVA,30H;A←(30H)返回本节4.1.3伪指令1.ORG:汇编起始地址用来说明以下程序段在存储器中存放的起始地址。例如程序:ORG1000HSTART:MOVA,#20HMOVB,#30

3、H┇2.EQU:赋值给变量标号赋予一个确定的数值。3.DB:定义数据字节把数据以字节数的形式存放在存储器单元中。4.DW:定义数据字按字的形式把数据存放在存储单元中。5.DS:定义存储区从指定的地址单元开始,保留一定数量存储单元。6.BIT:位定义确定字符名为确定的位地址值。7.END:汇编结束返回本节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所示。参考程序如下:ORG2000HMOVA,30H;取值ANLA,#0FH;取低4位ADDA,#30H;转换成ASCII码MOV32H,A;保存结果MOVA,30H;取值SWAPA;高4位与低4位互换ANLA,#0FH;取低4位(原来的高4位)ADDA,#30H;转换成ASCII码MOV31H

5、,A;保存结果SJMP$END结束取数据低4位转换成ASCII码存ASCII码取数据高4位转换成ASCII码存ASCII码开始图4-1拆字程序流程图结束取数据X求X2暂存X2取数据Y求Y2求X2+Y2开始保存平方和图4-2例4.2程序流程图【例4.2】设X、Y两个小于10的整数分别存于片内30H、31H单元,试求两数的平方和并将结果存于32H单元。解:两数均小于10,故两数的平方和小于100,可利用乘法指令求平方。程序流程如图4-2所示。参考程序如下:ORG2000HMOVA,30H;取30H单元数据MOVB,A;将X送入B寄存器MULAB;求X

6、2,结果在累加器中MOVR1,A;将结果暂存于R1寄存器中MOVA,31H;取31H单元数据MOVB,A;将Y送入B寄存器MULAB;求Y2,结果在累加器中ADDA,R1;求X2+Y2MOV32H,A;保存数据SJMP$;暂停END结束取数据X求X2暂存X2取数据Y求Y2求X2+Y2开始保存平方和图4-2例4.2程序流程图返回本节4.2.3分支程序1.分支程序的基本形式分支程序有三种基本形式,如图4-3所示。分支程序的设计要点如下:(1)先建立可供条件转移指令测试的条件。(2)选用合适的条件转移指令。(3)在转移的目的地址处设定标号。条件满足?A

7、YN(a)条件满足?ABNY(b)(c)A0A1AnK=0K=1…K=nK=?……图4-3分支程序结构流程图2.双向分支程序设计举例【例4.3】设X存在30H单元中,根据下式X+2X>0Y=100X=0求出Y值,将Y值存入31H单元。∣X∣X<0解:根据数据的符号位判别该数的正负,若最高位为0,再判别该数是否为0。程序流程如图4-4所示。参考程序如下:ORG1000HMOVA,30H;取数JBACC.7,NEG;负数,转NEGJZZER0;为零,转ZER0ADDA,#02H;为正数,求X+2AJMPSAVE;转到SAVE,保存数据ZER0:MOV

8、A,#64H;数据为零,Y=100AJMPSAVE;转到SAVE,保存数据NEG:DECA;CPLA;求∣X∣SAVE:MOV31H,A

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。