微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > 51单片机指令详解

51单片机指令详解

时间:11-19 来源:互联网 点击:

ata

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

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

  4.乘法指令

    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。

  6.加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 9; ( 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类指令的对象则广泛得多,可以是寄存器、内存地址、间址寻址的地址等等。

  7.减1指令

    DEC A

    DEC RN

    DEC direct

    DEC @Ri

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

  逻辑运算类指令:

  1.对累加器A的逻辑操作:

    CLR A ;将A中的值清0,单周期单字节指令,与MOV A,#00H效果相同。

    CPL A ;将A中的值按位取反

    RL A ;将A中的值逻辑左移

    RLC A ;将A中的值加上进位位进行逻辑左移

    RR A ;将A中的值进行逻辑右移

    RRC A ;将A中的值加上进位位进行逻辑右移

    SWAP A ;将A中的值高、低4位交换。

    例:(A)=73H,则执行CPL A,这样进行:

    73H化为二进制为00011,

    逐位取反即为 00,也就是8CH。

    RL A是将(A)中的值的第7位送到第0位,第0位送1位,依次类推。

    例:A中的值为68H,执行RL A。68H化为二进制为01101,按上图进行移动。01101化为11010,即D0H。

    RLC A,是将(A)中的值带上进位位(C)进行移位。

    例:A中的值为68H,C中的值为1,则执行RLC A

    1 01101后,结果是0 11011,也就是C进位位的值变成了0,而(A)则变成了D1H。

    RR A和RRC A就不多谈了,请大家参考上面两个例子自行练习吧。

    SWAP A,是将A中的值的高、低4位进行交换。

    例:(A)=39H,则执行SWAP A之后,A中的值就是93H。怎么正好是这么前后交换呢?因为这是一个16进制数,每1个16进位数字代表4个二进位。注意,如果是这样的:(A)=39,后面没H,执行SWAP A之后,可不是(A)=93。要将它化成二进制再算:39化为二进制是10,也就是1,0高4位是1,低4位是0,交换后是01,也就是71H,即113。

  2.逻辑与指令

    ANL A,Rn ;A与Rn中的值按位与,结果送入A中

    ANL A,direct ;A与direct中的值按位与,结果送入A中

    ANL A,@Ri ;A与间址寻址单元@Ri中的值按位与,结果送入A中

    ANL A,#data ;A与立即数data按位与,结果送入A中

    ANL direct,A ;direct中值与A中的值按位与,结果送入direct中

    ANL direct,#data ;direct中的值与立即数data按位与,结果送入direct中。

    这几条指令的关键是知道什么是逻辑与。这里的逻辑与是指按位与

    例:71H和56H相与则将两数写成二进制形式:

    (71H) 01

    (56H) 00100110

    结果 00100 即20H,从上面的式子可以看出,两个参与运算的值只要其中有一个位上是0,则这位的结果就是0,两个同是1,结果才是1。

    理解了逻辑与的运算规则,结果自然就出来了。看每条指令后面的注释

    下面再举一些例子来看。

      MOV A,#45H ;(A)=45H

      MOV R1,#25H ;(R1)=25H

      MOV 25H,#79H ;(25H)=79H

      ANL A,@R1 ;45H与79H按位与,结果送入A中为 41H (A)=41H

      ANL 25H,#15H ;25H中的值(79H)与15H相与结果为(25H)=11H)

      ANL 25H,A ;25H中的值(11H)与A中的值(41H)相与,结果为(25H)=11H

    在知道了逻辑与指令的功能后,逻辑或和逻辑异或的功能就很简单了。

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top