设计与开发

单片机的乘法指令 跟电师傅学单片机(13):单片机算术运算类指令图文讲解

小编 2024-10-23 设计与开发 23 0

跟电师傅学单片机(13):单片机算术运算类指令图文讲解

一:加一减一指令(共9条)

单片机加一减一指令表

1、INC:单片机加1指令(共5条),主要用于修改地址指针和计数次数,只有一个操作数。

指令功能:是将操作数所确定的单元或寄存器中的内容加1,最后将结果还是送回原操作数单元中。

操作数:累加器A、寄存器Rn、直接地址direct、寄存器间接寻址单元、数据指针寄存器DPTR中的内容。

2、DEC:单片机减1指令(共4条),只有一个操作数,与INC指令类似。

指令功能:是将操作数所确定的单元或寄存器中的内容减1,最后将结果还是送回原操作数单元中。

操作数:累加器A、寄存器Rn、直接地址direct、寄存器间接寻址单元中的内容。

二:十进制调整指令(1条)

DA A

单片机十进制调整指令,功能是在进行BCD码加法运算时,用来对BCD码的加法运算结果自动进行修正,修正结果存放在A中。

BCD码:是二进码十进数或二-十进制代码,用4位二进制数来表示1位十进制数中的0~9这10个数码。

注意:

1:在进行BCD加法运算时,在单片机加法指令ADD或ADDC指令后紧跟着DA A指令,单片机自动判断和修正。

2:对BCD码的减法运算时不能用DA A指令不进行修正,不适用减法指令。

3:影响PSW中CY、AC、OV标志位。(请看下图:标志寄存器PSW功能图)

三:乘法指令(1条)

MUL AB

单片机乘法指令,功能是实现2个8位无符号数的乘法运算,相乘的2个数分别存放在累加器A中和寄存器B中,乘积结果为16位:低8位存放在A中,高8位存放在B中。

注意:

1:乘数和被乘数可以交换。

2:乘积结果大于255,PSW中的溢出标志位OV置1,否则为0 。

单片机标志寄存器PSW功能图

单片机指令举例:

02H和04H的乘法运算

MOV A,#02H

MOV B,#04H

MUL AB

执行指令结果:

A:08H

B:00H

OV:0

四:除法指令(1条)

DIV AB

单片机除法指令,功能是实现2个8位无符号数的除法运算,被除数放在累加器A中,除数放在寄存器B中。相除结果:商放在A中,余数放在B中。

注意:

单片机除法指令也影响PSW中CY和OV标志位,相除之后CY和OV均为0。(请看上图:标志寄存器PSW功能图)

单片机指令举例:

22和4的除法运算

MOV A,#22

MOV B,#04

MUL AB

执行指令结果:

A:05H

B:02H

CY:0

OV:0

单片机乘除法指令

到此为止,24条单片机算术运算类指令讲解完毕,谢谢阅读!欢迎留言讨论,共同提高!

单片机算术运算类指令整理

一、不带进位位的单片机加法指令 

ADD A,#DATA ;例:ADD A,#10H 

ADD A,direct ;例:ADD A,10H 

ADD A,Rn ;例:ADD A,R7 

ADD A,@Ri ;例:ADD A,@R0

用途:将A中的值与其后面的值相加,最终结果否是回到A中。

例:

MOV A,#30H ADD A,#10H

则执行完本条指令后,A中的值为40H。 下面的题目自行练习 

MOV 34H,#10H

MOV R0,#13H 

MOV A,34H 

ADD A,R0 

MOV R1,#34H 

ADD A,@R1

二、带进位位的加法指令

ADDC A,Rn 

ADDC A,direct 

ADDC A,@Ri 

ADDC A,#data

用途:将A中的值和其后面的值相加,并且加上进位位C中的值。

说明:由于51单片机是一种8位机,所以只能做8位的数学运算,但8位运算的范围只有0-255,这在实际工作中是不够的,因此就要进行扩展,一般是将2个8位的数学运算合起来,成为一个16位的运算,这样,能表达的数的范围就能达到0-65535。如何合并呢?其实很简单,让我们看一个10进制数的例程: 66+78。

这两个数相加,我们根本不在意这的过程,但事实上我们是这样做的:先做6+8(低位),然后再做6+7,这是高位。做了两次加法,只是我们做的时候并没有刻意分成两次加法来做罢了,或者说我们并没有意识到我们做了两次加法。之所以要分成两次来做,是因为这两个数超过了一位数所能表达的范置(0-9)。 在做低位时产生了进位,我们做的时候是在适当的位置点一下,然后在做高位加法是将这一点加进去。那么计算机中做16位加法时同样如此,先做低8位的,如果两数相加产生了进位,也要“点一下”做个标记,这个标记就是进位位C,在PSW中。在进行高位加法是将这个C加进去。例:1067H+10A0H,先做

67H+A0H=107H,而107H显然超过了0FFH,因此最终保存在A中的是7,而1则到了PSW中的CY位了,换言之,CY就相当于是100H。然后再做10H+10H+CY,结果是21H,所以最终的结果是2107H。

三、带借位的单片机减法指令

SUBB A,Rn 

SUBB A,direct 

SUBB A,@Ri 

SUBB A,#data

设(每个H,(R2)=55H,CY=1,执行指令SUBB A,R2之后,A中的值为73H

说明:没有不带借位的单片机减法指令,如果需要做不带位的减法指令(在做第一次相减时),只要将CY清零即可。

四、乘法指令 MUL AB

此单片机指令的功能是将A和B中的两个8位无符号数相乘,两数相乘结果一般比较大,因此最终结果用1个16位数来表达,其中高8位放在B中,低8位放在A中。在乘积大于FFFFFH(65535)时,0V置1(溢出),不然OV为0,而CY总是0。

例:(A)=4EH,(B)=5DH,执行指令

MUL AB后,乘积是1C56H,所以在B中放的是1CH,而A中放的则是56H。

5、除法指令DIV AB

此单片机指令的功能是将A中的8位无符号数除了B中的8位无符号数(A/B),除法一般会出现小数,但计算机中可没法直接表达小数,它用的是我们小学生还没接触到小数时用的商和余数的概念,如13/5.其商是2,余数是3。除了以后,商放在A中,余数放在B中。CY和OV都是0。如果在做除法前B中的值是00H,也就是除数为0,那么0V=1。

六、 加1指令 

INC A 

INC Rn 

INC direct 

INC @Ri

INC DPTR

用途很简单,就是将后面目标中的值加1。

例:(A)=12H,(R0)=33H,(21H)=32H,(34H)=22H,DPTR=1234H。执行下面的指令: 

INC A (A)=13H 

INC R2 (R0)=34H 

INC 21H (21H)=33H 

INC @R0 (34H)=23H 

INC DPTR ( DPTR)=1235H 后结果如上所示。

说明:从结果上看INC A和ADD A,#1差不多,但INC A是单字节,单周期指令,而ADD #1则是双字节,双周期指令,而且INC A不会影响PSW位,如(A)=0FFH,INC A后(A)=00H,而CY依然保持不变。如果是ADD A ,#1,则(A)=00H,而CY一定是1。因此加1指令并不适合做加法,事实上它主要是用来做计数、地址增加等用途。另外,加法类指令都是以A为核心的其中一个数必须放在A中,而运算结果也必须放在A中,而加1类指令的对象则广泛得多,能是寄存器、内存地址、间址寻址的地址等等。

七、减1指令 

DEC A 

DEC RN 

DEC direct 

DEC @Ri

与加1指令类似,就不多说了。 

综合练习: 

MOV A,#12H 

MOV R0,#24H 

MOV 21H,#56H 

ADD A,#12H 

MOV DPTR,#4316H 

ADD A,DPH 

ADD A,R0 CLR C 

SUBB A,DPL 

SUBB A,#25H 

INC A SETB C 

ADDC A,21H 

INC R0 

SUBB A,R0 

MOV 24H,#16H 

CLR C 

ADD A,@R0

先写出每步运行结果,然后将以上题目建入,并在软件仿真中运行,观察寄存器及有关单元的内容的变化,是否与自已的预想结果相同。

相关问答

一个 单片机的乘法指令 ?

单片机乘法指令是MULAB,只能是累加器A和寄存器B相乘,结果低八位存入A,高八位存入B。比如题中,A=4EH,B=5DH,A*B=1C56H,所以A=56H,B=1CH单片机乘法指令是MULAB,...

51 单片机乘法指令 是如何运行的?

五一单片机中乘法指令在运行的时候事先对低位香肠,然后把精卫放到寄存器a中,然后高位再进行相乘。最终的结果会放在两个变量中分,别代表的是高八位和低八位。...

单片机 乘法 ?

整数的乘法很好理解啊,比如A×B,就是A重复累加B次,比如要求C=A×B:代码示例:intA,B,C,i;C=0;for(i=0;i整数的乘法很好理解啊,比如A×B,就是A重复累加B次.....

求问 单片机的 MUL 指令 怎么计算?

MUL指令是51单片机唯一的乘法指令,具体为:MULAB,将累加器A与寄存器B的数据相乘,结果低位存入A,高位存入B。MUL指令是51单片机唯一的乘法指令,具体为:MULAB,...

8051 单片机 机一条 乘法指令 需要执行多长时间?

8051单片机中的乘法指令需要执行多长时间取决于所使用的操作数的位数以及CPU的时钟频率。在一般情况下,单片机的乘法指令执行时间需花费4至12个机器周期,即约...

单片机指令 周期的计算?

1、时钟周期时钟周期T又称为状态周期,是时序中最小的时间单位。具体计算就是1/fosc。也就是说如果晶振为1MHz,那么时钟周期就为1us;6MHz的话,就是1/6us。...

单片机 指令 周期、机器周期、状态周期、振荡时钟周期(时...

[最佳回答]时钟周期:时钟周期也称为振荡周期,定义为时钟脉冲的倒数(可以这样来理解,时钟周期就是单片机外接晶振的倒数,例如12M的晶振,它的时间周期就是1/12u...

stc15w4k 单片机的 优点?

1、抗干扰能力强;2、保密性能强悍,很难被破解;3、单片机时钟有防外部电磁辐射功能;stc单片机缺点:1、功耗较高,5V供电;2、8位,运行速度慢;3、无硬...3...

C语言程序中,使用移位操作代替乘除运算,真的效率更高吗?

先简单小结一下:当编译器优化能力很弱时,用移位代替简单除法(除2,4,8,16...)效率更高;当编译器优化能力很弱时,在低端CPU上,用移位代替简单乘法(乘2...低端...

谁帮我做一下谢谢判断题:18道,每道5分,总分90 1.MCS-51 单片机 在物理上有四个独立的存储器空间,正确,错误?

判断题:18道,每道5分,总分901.MCS-51单片机在物理上有四个独立的存储器空间正确2.当MCS-51单片机配有6MHz晶振时,一个机器周期为2微秒正确3.当MCS-51单片...

猜你喜欢