单片机教程汇编程序设计.ppt

上传人:sccc 文档编号:5815534 上传时间:2023-08-23 格式:PPT 页数:61 大小:515.01KB
返回 下载 相关 举报
单片机教程汇编程序设计.ppt_第1页
第1页 / 共61页
单片机教程汇编程序设计.ppt_第2页
第2页 / 共61页
单片机教程汇编程序设计.ppt_第3页
第3页 / 共61页
单片机教程汇编程序设计.ppt_第4页
第4页 / 共61页
单片机教程汇编程序设计.ppt_第5页
第5页 / 共61页
点击查看更多>>
资源描述

《单片机教程汇编程序设计.ppt》由会员分享,可在线阅读,更多相关《单片机教程汇编程序设计.ppt(61页珍藏版)》请在三一办公上搜索。

1、第4章:汇编语言程序设计,本章基本要求:汇编语言的构成 源程序的设计与汇编*应用程序设计*,4.1汇编语言的构成,4.1.1程序设计语言用户要使计算机能完成各式各样的任务,就要设计各种相应的应用程序,而设计程序就要用到程序设计语言。程序设计语言有3种:机器语言汇编语言高级语言。,4.1汇编语言的构成,表4-1 机器语言和汇编语言的形式,机器语言中二进制形式不便记忆,常采用十六进制形式记忆,4.1汇编语言的构成,在Keil调试环境下反汇编程序,1、汇编源程序:,2、反汇编程序:,地址,机器码,反汇编程序,汇编源程序,4.1汇编语言的构成,1、机器语言计算机能直接识别和执行的二进制代码形式的指令称

2、为机器指令,而该类指令的集合称为计算机的机器语言,或称指令系统。机器语言是面向计算机系统的。由于各种计算机内部结构,线路的不同,每种计算机系统都有它自己的机器语言,即使执行同一操作,其指令也不相同。,4.1汇编语言的构成,2、汇编语言计算机所能执行的每条指令都对应一组二进制代码。为了容易理解和记忆计算机的指令,人们用一些英语的单词和字符以及数字作为助记符来描述每一条指令的功能。用助记符描述的指令系统,称为机器的汇编语言系统,简称汇编语言。汇编语言也是面向机器的,每种计算机系统也都有它自己的汇编语言,用汇编语言编写的程序,称为汇编语言源程序或汇编源程序。,4.1汇编语言的构成,3、高级语言 高级

3、语言(如:PASCAL、C、FORTRAN、BASIC等)克服了汇编语言的缺点,是一种面向问题或过程的语言。它是一种接近于自然语言和数学算法的语言,与机器的硬件无关,用户编程时不必仔细了解所用计算机的具体性能和指令系统。高级语言不但直观、易学、易懂,而且通用性强,可以在不同的计算机上运行,因此可移植性好。,4.1汇编语言的构成,4.1.2汇编语言格式MCS51系列单片机是用51系列单片机的指令系统来编程的,其汇编语言的语句格式,也就是单片机的指令格式,即:标号:操作码 操作数;注释说明:1、内的部分为可选项;2、标号是一条指令在存储器存放的地址,是以字母开头的字母数字串,不可以是保留字;3、操

4、作码和操作数必须按照指令格式书写;,4.1汇编语言的构成,举例:ORG0060H START:MOV A,#00H;A0MOV R2,#0AH;R210MOVR1,#03H;R13 LOOP:ADDA,R1;AA+R1 DJNZ R2,LOOP;若R2-10,则跳到LOOP NOP SJMP$END,4.1汇编语言的构成,4、操作数可以写成以下形式(5种-128页):二进制、十进制、十六进制形式工作寄存器、特殊功能寄存器地址标号带加减算符的表达式采用符,4.1汇编语言的构成,举例:MOV A,#00110101B;A53 MOV A,#20D;A20 MOV A,#20;A20 MOV R0,

5、#20H;R020HMOVR1,#0BFH;R1BFH SJMP$;原地跳转 MOV R7,R2;R7R2 MOV A,LABLE;A标号地址 MOV A,LABLE+1;A标号地址+1,4.1汇编语言的构成,4.1.3汇编语言构成汇编语言语句分为:指令性语句、指示性语句两类。1、指令性语句包括指令系统中的全部指令,每条指令有对应的机器代码,并可由CPU执行。2、指示性语句在汇编源程序的过程中,还有一些指令不要求CPU进行任何操作,也没有对应的机器码,不影响程序的执行,仅仅是能够指导汇编进行处理的一些指令,称之为伪指令。,4.1汇编语言的构成,伪指令的主要功能是:用来指定程序或数据的起始位置,

6、给出一些连续存放数据的确定地址,或为中间运算结果保留一部分存储空间以及表示源程序结束等等。不同版本的汇编语言,伪指令的符号和含义可能有所不同,但是基本用法是相似的。下面介绍几种常用的基本伪指令。,MCS-51单片机伪指令,1、起点指令 ORG,格式:,ORG H(16位地址或标号),功能:,给程序起始地址或数据块的起始地址赋值,例:,用法:,一般出现在每段源程序或数据块的开始一个源程序可多次出现ORG指令,首地址,首地址,2、结束命令 END,格式:END,功能:汇编程序结束标志,附在一个源程序的结尾 一个源程序只能出现一次END指令,用法:,MCS-51单片机伪指令,3、等值命令 EQU,格

7、式:,字符名称 EQU 数据或汇编符号,功能:,将一个数据或汇编符号赋予标号段规定的字符名称,例:,;AA与R6等值,MCS-51单片机伪指令,例:,A10 EQU 10DELY EQU 07EBH MOV A,A10 LCALL DELY,;A10=10,;DELY=07EBH,;转向入口地址 07EBH,使用EQU指令,须先赋值后使用,不能反之,4、数据地址赋值等值命令 DATA,格式:,字符名称 DATA 数据或表达式,功能:,此命令把数据/代码地址赋予标号段所规定的字符名称。定义的字符名称可先使用后定义,INDEXJ DATA 8096H,;INDEXJ这个字符名称的地址为8096H,

8、例:,等价于,MCS-51单片机伪指令,EQU与 DATA的区别,(1)DATA与EQU相似,但DATA定义的字符名称,可先使用后定义,EQU则不能,(2)EQU指令可把汇编符号赋给字符名称,DATA则不能,(3)DATA可把表达式的值赋给字符名称,EQU则不能,DATA常在程序中定义数据地址EQU常在程序中定义字符数据,MCS-51单片机伪指令,5、定义字节命令 DB,格式:,功能:,标号:DB 字节常数或字符串(8位),定义字节的内容,汇编程序把DB定义的字节依次存入标号开始的存储单元,有定义的内存单元地址,项或项表,例:,伪指令ORG 定义了TAB的起始地址为8000H,伪指令DB定义了

9、8000H8003单元的内容依次为:,(8000H)=45H,(8001H)=49H,(8002H)=35H,(8003H)=41H,(8004H)=05H,TAB,TAB1,(1)由 ORG定义,(2)跟在其他源程序之后,6、定义字命令DW,格式:,功能:,标号:DW 字或字表,定义若干个字(双字节),例:,ORG 8000H,TAB:DW 7234H,8AH,10,(8000H)=72H,(8001H)=34H,(8002H)=00H,(8003H)=8AH,(8005H)=0AH,汇编后:,(8004H)=00H,MCS-51单片机伪指令,7、定义空间命令 DS,格式:,功能:,标号:D

10、S 数据或字符及表达式,例:,(8008H)=30H,(8009H)=8AH,从指定单元地址开始,由数据或字符及表达式的值来定义应保留的单元数,备用,即:8000H8007H单元保留备用,定义空间,MCS-51单片机伪指令,8、位地址符号命令 BIT,格式:,字符名称 BIT 位地址,功能:,把位地址赋予标号段的字符名称,;P1.0,P2.0赋予位地址字符名称 A1、A2,在编程时可以直接把 A1、A2 当成位地址使用,MCS-51单片机伪指令,汇编程序的操作,分两次扫描(汇编),第一次扫描(汇编),检查语法结构,对源程序中的符号、表达式、标号进行定义,处理伪指令,建立符号表,显示 ERROR

11、,并提示行号,显示 ERROR,并提示行号,修改!,修改!,第二次扫描(汇编),汇编成目标代码和汇编程序清单,可执行的代码(机器码),4.2汇编源程序的设计与汇编,4.2.1汇编程序设计步骤1、确定方案和计算方法2、了解应用系统的硬件配置、性能指标。3、建立系统数学模型,确定控制算法和操作步骤。4、画程序流程图,表示程序结构和程序功能。5、编制源程序 合理分配存储器单元和了解I/O接口地址。按功能设计程序,明确各程序之间的相互关系。用注释行说明程序,便于阅读和修改调试和修改。6、上机调试,对程序的正确性作最后的确定。,4.2 汇编源程序的设计与汇编,程序设计步骤流程:,Y,N,Y,Y,Y,N,

12、N,N,4.2汇编源程序的设计与汇编,4.2.2源程序的汇编CPU可以执行的只能是机器码程序。称:把源程序翻译成机器码的过程为汇编。汇编可:人工汇编和机器汇编两类。1、人工汇编由人工直接将汇编源程序翻译成机器码。2、机器汇编使用计算机执行“汇编程序”来代替人工实现将汇编源程序翻译成机器码。,汇编语言源程序,机器语言,汇编,反汇编,交叉汇编,例4.1 设在内部RAM的BLOCK单元内有一无符号数据块的长度,无符号数据块起始地址是BLOCK+1。试编程求无符号数据块种数据的累加和(不考虑进位加法之和),并把它存入SUM单元。程序:ORG1000HSUMDATA1FH BLOCKDATA 20H S

13、TART:MOVR0,#BLOCK;数据块长度地址送R0MOVA,R0;数据块长度送ACJNEA,#00H,LOOP;若数据块长度0,则LOOP HERE:SJMP$;若数据块长度=0,则结束 LOOP:CLRA NEXT:INC R0;修改数据指针ADDA,R0;加一个数DJNZ BLOCK,NEXT;若(BLOCK)-1 0,则NEXT MOV SUM,A;存累加和 SJMP HERE END,汇编程序经两次汇编得机器码 第一次汇编 第二次汇编,转移地址计算,LOOP=1008H-1003H-3=02H;NEXT=1009H-100BH-3=-5=0FBH$=1006H-1006H-2=-

14、2=0FEH;HERE=1006H-1010H-2=-12=0F4H,偏移地址=指令所在地址-跳转地址-指令字节数,4.3简单程序与分支程序设计,4.3.1简单程序设计例4.2请编写能把20H单元内两个BCD数变成相应的ASCII码并放在21H(高位BCD数的ASCII码)和22H(高位BCD数的ASCII码)单元的程序。程序:ORG 0500H MOV R0,#22H;R0=22H MOV R0,#00H;(22H)=0 MOV A,20H;A(20H)BCD码 XCHD A,R0;低位BCD码与22H半字节交换 ORL 22H,#30H;加30H完成ASCII码变换 SWAP A;高位BC

15、D码高低位半字节交换 ORL A,#30H;加30H完成ASCII码变换 MOV 21H,A;存入21H单元 SJMP$,例4.3已知一个补码形式的16位二进制(低8位在NUM单元,高8位在NUM+1单元),试编写能求该16位二进制数原码的绝对值得程序。程序:ORG 0300H NUM DATA 20H MOV R0,#NUM;R0=NUM MOV R0,A;低8位送入A CPL A;A求反 ADD A,#01H;A中内容变补,保留CY MOV R0,A;存数 INC R0;地址加1,指向高8位 MOV R0,A;高8位送入A CPL A;取反 ADDC A,#00H;加进位 ANL A,#7

16、FH;去掉符号位 MOV R0,A;存数 SJMP$,4.3简单程序与分支程序设计,例4.4已知20H单元中有一个8位二进制数,请编程把它转换为3位BCD数,把百位数存入FIRST单元的低4位,十位和个位BCD数放在SECOND单元,十位BCD数在SECOND单元的高4位。程序:ORG 0200H FIRST DATA 30H SECOND DATA 31H MOV A,20H;A=(20H)MOV B,#64H;除数100 DIV AB;A/100 MOV FIRST,A;低8位送入A MOV A,B;余数送A MOV B,#0AH;除数10 DIV AB;A/10 SWAP A;十位BCD

17、送高4位 ORL A,B;完成十位和个位装配 MOV SECOND,A;存入SECOND单元 SJMP$,4.3简单程序与分支程序设计,4.3.2分支程序设计可分为无条件和有条件分支程序两类。重点以条件分支举例。例4.5 已知VAR单元内有一自变量,请按如下条件编出求函数值Y,并将它存入FUNC单元的程序。1 X0 Y=0 X=0-1 X0 解:这是一个三分支归一的条件转移问题。两种求解方法:“先分支后赋值”“先赋值后先分”,4.3简单程序与分支程序设计,“先分支后赋值”,程序:ORG 0100H VAR DATA 30H FUNC DATA 31H MOV A,VAR;AX JZ DONE;

18、若=0,则转DONE JNB ACC.7,POSI;若0,则转POSI MOV A,#0FFH;若0,则A-1 SJMP DONE;转DONE POSI:MOV A,#01H;则A 1 DONE:MOV FUNC,A;存结果 SJMP$END,Y,Y,N,N,一个判断决策框,程序有两条出路。两种分支结构:,例:求R2中补码绝对值,正数不变,负数变补。MOV A,R2 JNB ACC.7,NEXT;为正数?CPL A;负数变补 INC A MOV R2,ANEXT:SJMP NEXT;结束,例如 行李计价:当重量G5公斤,价格M=G3(元);当重量G5公斤,价格M=G3+(G-5)2(元),FR

19、T:MOV A,40H;取行李重量计价单位G MOV R3,A MOV B,#03H;M=G3 MUL AB MOV R2,A;暂存3G MOV A,R3;取回G CJNE A,#05H,L1;G5?SJMP WETC L1:JC WETC;是,转至WETC SUBB A,#05H;否则M=3G+2(G-5)RLC A ADD A,R2WETC:MOV 41H,A;存结果M RET,一、按分支号转移,如:当分支号=0,程序转移到ADDR0处;当分支号=1,程序转移到ADDR1处;。,(1)用地址表法。设分支号已存入A。MTJS:MOV DPTR,#TAB;取表首地址 CLR C;分支号2 RL

20、C A MOV R2,A MOVC A,A+DPTR;取分支地址低位 PUSH ACC;入栈保存 MOV A,R2 INC A MOVC A,A+DPTR;取分支地址高位 PUSH ACC;入栈保存 RET;分支地址PC,转移TAB:DW ADDR0;分支地址表 DW ADDR1 ADDR0:;程序段0,(2)转移表法。用分支转移指令 JMP A+DPTR。设R7R6=分支号,MTJS:MOV DPTR,#TAB;指向表首地址 MOV A,R7;分支号高字节3 MOV B,#03H MUL AB;乘积不超过1字节 ADD A,DPH MOV DPH,A MOV A,R6;分支号低字节3 MOV

21、 B,#03H MUL AB XCH A,B ADD A,DPH;DPHDPH+(R7、R6)3)高字节 MOV DPH,A XCH A,B;A(R7、R6)3)低字节 JMP A+DPTR;实现多分支转移TAB:LJMP ADDR0;转移表 LJMP ADDR1 LJMP ADDRNADDR0:;程序段0,4.4循环与查表程序设计,4.4.1循环程序设计循环程序一般由四部分组成:循环初始化、循环处理、循环控制、循环结束。循环程序一般使用两种结构,如下图:,循环程序的构成,各个环节任务:一初始化部分 循环准备工作。如:清结果单元、设指针、设循环控制变量初值等。,二循环体 循环工作部分:需多次重

22、复处理的工作。循环控制部分:1.修改指针和循环控制变量。2.检测循环条件:满足循环条件,继续循环,否则退出循环。三.结束部分 处理和保存循环结果。允许0次循环的循环结构:在循环工作之前检测循环条件。,4.4循环与查表程序设计,一、单重循环,例:求n个单字节数据的累加,设数据串已在43H起始单元,数据串长度在42H单元,累加和不超过2个字节。,SUM:MOVR0,#42H;设指针MOVA,R0MOVR2,A;循环计数器nCLRA;结果单元清0MOVR3,AADD1:INCR0;修改指针ADDA,R0;累加JNC NEXT;处理进位INCR3;有进位,高字节加1NEXT:DJNZ R2,ADD1;

23、循环控制:数据是否加完?MOV40H,A;循环结束,保存结果MOV41H,R3RET,简单循环结构:循环体中不套循环。,循环控制方法:计数控制、特征标志控制。,1、计数控制:设循环计数器,控制循环次数。正计数和倒计数两种方式。例:为一串7位ASCII码数据的D7位加上奇校验,设数据存放在片外RAM的2101H起始单元,数据长度在2100H单元。,MOV DPTR,#2100HMOVX A,DPTRMOV R2,ANEXT:INC DPTRMOVX A,DPTRORL A,#80HJNB P,PASSMOVX DPTR,APASS:DJNZ R2,NEXTDONE:SJMP DONE,2、特征控

24、制:设定循环结束标志实现循环控制。,例:找正数表最小值。正数表存在片外RAM中以LIST为起始单元,用-1作为结束标志。,START:MOV DPTR,#LIST;数表首地址 MOV B,#127;预置最小值NEXT:MOVX A,DPTR;取数 INC DPTR;修改指针 CJNE A,#-1,NEXT1;是否为数表结尾?SJMP DONE;循环结束NEXT1:CJNE A,B,NEXT2;比较NEXT2:JNC NEXT MOV B,A;保存较小值 SJMP NEXTDONE:SJMP DONE,二、多重循环,例将内存一串单字节无符号数升序排序。步骤:每次取相邻单元的两个数比较,决定是否需

25、要交换数据位置。第一次循环,比较N-1次,取到数据表中最大值。第二次循环,比较N-2次,取到次大值。第N-1次循环:比较一次,排序结束。,循环体中套循环结构。以双重循环使用较多。,SORT:MOV A,#N-1;N个数据排序 MOV R4,A;外循环次数LOOP1:MOV A,R4 MOV R3,A;内循环次数 MOV R0,#TAB;设数据指针LOOP2:MOV A,R0;取二数 MOV B,A INC R0 MOV A,R0 CJNE A,B,L1;比较L1:JNC UNEX;AB,不交换 DEC R0;否则交换数据 XCH A,R0 INC R0 MOV R0,AUNEX:DJNZ R3

26、,LOOP2;内循环结束?DJNZ R4,LOOP1;外循环结束?RET,4.4循环与查表程序设计,4.4.2查表程序设计所谓查表是依据ROM中的数据表格的项数来查找与之对应的表中数值。有两条专门的查表指令:MOVCA,A+DPTRMOVCA,A+PC查表指令一般用于代码转换、显示、散转等应用场合。,当用DPTR作基址寄存器时,查表的步骤分三步:基址值(表格首地址)DPTR;变址值(表中要查的项与表格首地址之间的 间隔字节数)A;执行MOVC A,A+DPTR。,当用PC作基址寄存器时,其表格首地址与PC值间距不能超过256字节,且编程要事先计算好偏移量,比较麻烦。因此,一般情况下用DPTR作

27、基址寄存器。,例:在单片机应用系统中,常用LED数码管显示数码,但显 示数字(9)与显示数字编码并不相同,需要将显示数 字转换为显示字段码,通常是用查表的方法。现要求 将30H中的显示数字转换为显示字段码并存入30H。已 知共阴字段码表首址为TABD。,程序如下:CHAG:MOV DPTR,#TABD;置共阴字段码表首址MOV A,30H;读显示数字 MOVC A,A+DPTR;查表,转换为显示字段码 MOV 30H,A;存显示字段码 RET;TABD:DB 3FH,06H,5BH,4FH,66H;04共阴字段码表 DB 6DH,7DH,07H,7FH,6FH;59共阴字段码表,程序如下:CU

28、BE:MOV DPTR,#TAB;置立方表首址MOV A,30H;读数据ADD A,30H;数据2AMOV 30H,A;暂存立方表数据序号 MOVC A,A+DPTR;读立方数据高8位XCH A,30H;存立方数据高8位,立方表数据序号AINC A;指向立方数据低8位MOVC A,A+DPTR;读立方数据低8位 MOV 31H,A;存立方数据低8位RET;TAB:DW 0,1,8,27,64,125,216,343,512,729,1000;040立方表 DW 1331,1728,2197,2744,3375,4096,64000;说明:数据2A原因是立方表数据为双字节,例:用查表程序求040

29、之间整数的立方。已知该整数存在内RAM 30H中,查得立方数存内RAM 30H(高8位)31H。已知立方表(双字节)首地址为TAB。,4.5子程序与运算程序设计,4.5.1 子程序设计回顾子程序的作用、结构、以及与主程序的关系。汇编程序设计中子程序调用方法、程序要求。设计子程序时注意:1、子程序的第一条指令的地址为入口地址。一般使用标号代替,该标号也叫做子程序名。2、子程序中必须使用RET指令。3、主程序调用子程序、子程序返回主程序时的操作。4、在子程序中注意保护CPU的状态。5、子程序入口参数的传送可以使用:指定RAM单元、R0R7寄存器、堆栈、位地址等来传送。,子程序设计一子程序入口用标号

30、作为子程序名。二调用子程序之前设置好堆栈。三用返回指令RET结束子程序,并保证堆栈栈顶为调用程序的返回地址。四.子程序嵌套须考虑堆栈容量。五.提供足够的调用信息:如:子程序名、子程序功能、入口参数和出口参数、子程序占用的硬件资源、子程序中调用的其他子程序名。,子程序:能完成某项特定功能的独立程序段,可被反复调用。,子程序的类型:按子程序与主程序之间传递参数的方式分类。,入口参数:调用子程序之前,需要传给子程序的参数。出口参数:子程序送回调用程序的结果参数。,选用不同的参数传递方式。1.寄存器传送参数 2.存储器传送参数 3.堆栈传送参数,设计子程序应满足通用性的要求,不针对具体数据编程。例如:

31、1.子程序功能为求单字节数的立方:AA3,入口参数和出口参数为A。2.子程序功能为求单字节数的n次方:(41H)(42H)(40H)A,入口参数为(40H)和A,出口参数为(42H)(41H)。,例:将R4R5R6中三个字节数据对半分解,变成6个字节,存入显示缓冲区(DISMEM0DISMEM5)。,1)子程序UFOR1的功能:将A累加器中单字节数据,对半分解成两个字节,存入R0所指向的相邻两个单元UFOR1:MOV R0,#0XCHD A,R0;保存低半字节INC R0;修改指针MOV R0,#0SWAP AXCHD A,R0;保存高半字节RET2)调用子程序UFOR1之前,将待分解的内容送

32、A,存放地址送R0。,例 比较两个数据串是否完全相等,若完全相等,A=0;否则A=FFH。,PMT:MOVR2,A;设数串长度CHC:MOVA,R0;各取数串中的一个数MOV42H,R1CJNE A,42H,NOM;是否相等?不相等转移INCR0;相等,修改指针INCR1DJNZ R2,CHC;全部比较完?MOVA,#0;完全相等SJMP PENDNOM:MOVA,#0FFH;不完全相等PEND:RET,例:查表求出数据的ASCII码,再以字符形式输出。,1)子程序HEXASC功能:取出堆栈中数据,查表将低半字节转换成ASCII码送累加器A。2)分别将待转换数据入栈,然后调用子程序HEXASC

33、。,MOV SP,#30H PUSH 40H;入口参数入栈 LCALL HEXASC POP ACCHEXASC:DECSP;跳过返回地址 DECSP POPACC;取入口参数;查表求ASCII码 PUSH ACC;保存出口参数 INCSP;指向返回地址 INCSP RET DB 0,1,;ASCII码表,4.5子程序与运算程序设计,例:设计100 ms延时程序。说明:计算机执行一条指令需要一定的时间,由一些指令组成一段程序,并反复循环执行,利用CPU执行程序所用的时间来实现延时,这种程序称为延时程序。如当系统使用12MHz晶振时,一个机器周期为1s,执行一条双字节双周期DJNZ指令的时间为2

34、s,因此,执行该指令50000次,就可以达到延时100ms的目的。对于50000次循环可采用外循环、内循环嵌套的多重循环结构。,4.5子程序与运算程序设计,程序清单:START:ORG1000HMOVR6,0C8H;外循环200次LOOP1:MOVR7,0F8H;内循环248次NOP;时间补偿LOOP2:DJNZR7,LOOP2;时2248=496sDJNZR6,LOOP;延时500200=100 msRET 以上程序执行MOV Rn,data指令的时间为1s,DJNZ指令2s,NOP指令1s,所以,内循环延迟时间:1s+1s+2s248=498s,外循环延迟时间:1s+(内环延时+2s)20

35、0=100.001 ms。,4.5子程序与运算程序设计,4.5.2运算程序设计 分为浮点运算程序和定点运算程序。本课程只介绍定点运算程序。,1.多字节加法子程序,Z=X+Y。ADDS:CLRCLOOP:MOVA,R0ADDC A,R1;加一字节MOVR0,A;存和一字节INCR0;修改指针INCR1DJNZ R2,LOOP;全部字节加完?RET,多字节无符号数乘除运算,相加计算多字节乘法程序,步骤:1.部分积清零。2.检测乘数各位,为1则部分积对位加被乘数,否则加0。3.对位方法:被乘数左移或部分积右移。,初值:0 00 Cy R4R5 右移R6R7并检测Cy+R2R3 当Cy=1 Cy R4

36、R5 得部分积并右移对位 乘积最后右移一次,例:双字节相乘 R2R3R6R7R4R5R6R7解:部分积清零,右移检测乘数,决定部分积是否加被乘数,部分积右移对位。,循环16次,4-7-3 代码转换程序,(二)ASCII码转换为十六进制数,0 9的ASCII码:30 39H,A F的ASCII码:41 46H。,HASC:CJNE A,#0AH,NAHEX:CLR CN:JNC N1SUBBA,#30HADD A,#30HCJNEA,#0AH,NSJMPSEN:JC N1N1:ADD A,#37HSJMP AESE:RETN1:SUBB A,#11HCJNE A,#06H,N2N2:JNCERRADDA,#0AHSJMP AEERR:MOVA,#0FFHAE:RET,(一)十六进制数转换为ASCII码,

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 建筑/施工/环境 > 农业报告


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号