当前位置:首页 > 单片机 > 单片机
[导读]算术运算指令的主要功能是实现算术加、减、乘、除等运算。1.ADD类指令是不带进位的加法运算指令(4条)。ADD A,Rn ;A+Rn→A, A与Rn寄存器内容相加,结果送到A中ADD A,direct ;(direct)+A→

算数运算指令

算术运算指令的主要功能是实现算术加、减、乘、除等运算。

1.ADD类指令是不带进位的加法运算指令(4条)。

ADD A,Rn          ;A+Rn→A, A与Rn寄存器内容相加,结果送到A中

ADD A,direct      ;(direct)+A→A, A与直接地址内容相加,和送A

ADD A, @Ri      ;(Ri)+A→A, A与Ri间址内容相加,和送A

ADD A, #data      ;data+A→A, A与立即数相加,和送A

注意:ADD类指令相加结果均在A中,相加后源操作数不变。若A中最高位有进位,Cy置1;若半加位有进位,AC置1。A的结果还影响奇偶标志位P。

 

例  A=30H, R0=10H

执行  ADD A,R0  结果:A=40H, R0=10H,标志位 P=1, Cy=0, OV=0, AC=0

2.ADDC类指令(带进位加法4条)

ADDC A, Rn      ;A+Rn+Cy→A,  A与R n内容、进位状态相加,和送

到A中

ADDC A, direct     ;(direct)+Cy+A→A, A与直接地址中内容、进位状态

相加,和送A

ADDC A, @Ri      ;(Ri)+Cy+A→A, A与Ri间址单元中内容、进位状态

相加,和送A

ADDC A, #data         ;data+Cy+A→A, A与 立即数、进位状态相加,和送A

与ADD类指令的区别是,ADDC指令相加时连同进位标志Cy内容一起相加,主要用于多字节加法中的高位字节的相加,而最低位字节相加用ADD指令。进位位Cy加到字节的最低位。

例  写计算1234H+0FE7H的程序,将结果存入内部RAM的41H和40H单元,40H存低8位,41H存高8位。

程序

MOV A, #34H   ;被加数低8位数34H送A

ADD A, #0E7H   ;加数低8位数E7H与之相加,A=1BH,Cy=1

MOV 40H, A   ;A→40H即34H+E7H结果存入40H中(40H=1BH)

MOV A, #12H   ;被加数高8位数12H送A

ADDC A, #0FH   ;加数高8位0FH和Cy与A相加,A=22H

MOV 41H, A   ;高8位与进位位之和存入41H中(41H)=22H

;总和为221BH,总结果在41H,40H单元中

3.SUBB类指令(4条)

SUBB类指令是带借位减法指令,其功能是将A中被减数减去源操作数指出的内容,再减去借位标志Cy(原进位标志)状态,差值在A中。

SUBB A, Rn    ;A-Rn-Cy→A ,A减寄存器Rn内容及进位标志

SUBB A, direct   ;A-(direct)-Cy→A,A减直接地址内容和进位标志

SUBB A, Ri    ;A-(Ri)-Cy→A, A减Ri间址单元内容和进位位标志

SUBB A, #data   ;A-data-Cy→A, A减立即数和进位标志

说明:

1) 多字节减法时,低位相减有借位则把Cy置1,否则Cy为0。

2) MCS-51系列指令中没有不带借位的减法指令,所以在单字节或低位字节减法时用SUBB类指令前要先将Cy清0。

3)减去一个数实际上是加上这个数的相反数(负数),减法运算常常用补码相加方式。

4.MUL(乘)和DIV(除)指令

乘法指令只有一条:

MUL  AB          ;A×B→B和A,结果16位,高8位存入B,低8位在A中

若乘积大于FFH则将溢出标志OV置1。

除法指令也只有一条:

DIV  AB              ; A÷B商→A,余数→B

注意:当除数为0时结果不确定,则溢出将OV置1。

5.INC(加1)和DEC(减1)类指令

加1类指令共5条,其功能是将操作数内容加1。

INC A     ;A+1→A, A加1

INC   Rn         ;Rn+1→Rn, Rn中内容加1

INC   direct       ;(direct)+1→(direct), 直接地址中内容加1

INC @Ri        ;(Ri)+1→(Ri), Ri间址中的内容加1

INC   DPTR    ;DPTR+1→DPTR, 数据指针加1

例  判断INC R0和INC @R0两条指令结果,比较两者的区别。设R0=30H,(30H)=00H。

执行  INC   R0            ;R0+1=30H+1→R0, 结果R0=31H

执行  INC   @R0           ;(R0)+1=(30H)+1→(R0),结果(30H)=01H,R0中内

容不变,仍为30H

减1类指令共4条,其功能是将操作数指定单元内容减1。

DEC  A     ;A-1→A, A中内容减1

DEC  Rn         ;Rn-1→Rn, Rn中内容减1

DEC  direct    ;(direct)-1→(direct), 直接地址中内容减1

DEC  @Ri         ;(Ri)-1→(Ri), Ri间址中的内容减1

操作过程与加1指令类似,这里不再举例。

6.十进制加法调整指令(1条)

DA   A

功能:在加法指令后,把A中二进制码自动调整成BCD码。

例   MOV  A, #05H       ;05H→A

ADD  A, #08H       ;05H+08H→A=0DH

DA   A        ;结果调整A=13H,即是13的BCD码

注意:DA A指令只能跟在ADD或ADDC加法指令后,不适用于减法。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭