在这里,我们将看到除法运算。使用此8051微控制器,此操作将被用于除以两个8位数字。寄存器A和B将用于此操作。没有其他寄存器可用于除法。除法的结果分为两个部分。商部分和余数部分。寄存器A将保留商数,寄存器B将保留余数。
我们在位置20H和21H取两个数字0EH和03H,相除后的结果将存储在位置30H和31H。
地址 |
值 |
---|---|
|
… |
20小时 |
0EH |
21小时 |
03H |
|
… |
30小时 |
00小时 |
31小时 |
00小时 |
|
… |
MOV R0, #20H ; set source address 20H to R0 MOV R1, #30H ; set destination address 30H to R1 MOV A, @R0 ; take the first operand from source to register A INC R0 ; Point to the next location MOV B, @R0 ; take second operand from source to register B DIV AB ; Divide A by B MOV @R1, A ; Store Quotient to 30H INC R1 ; Increase R1 to point to the next location MOV @R1, B ; Store Remainder to 31H HALT: SJMP HALT ; Stop the program
8051提供了DIV AB指令。通过使用此指令,可以完成除法。在某些其他微处理器(如8085)中,没有DIV指令。在该微处理器中,我们需要使用重复的减法运算来获得除法结果。
当分母为00H时,溢出标志OV为1,否则除法为0。
输出结果
地址 |
值 |
---|---|
|
… |
20小时 |
0EH |
21小时 |
03H |
|
… |
30小时 |
04小时 |
31小时 |
02小时 |
|
… |
本文向大家介绍程序将8051微处理器中的两个8位数字相乘,包括了程序将8051微处理器中的两个8位数字相乘的使用技巧和注意事项,需要的朋友参考一下 在这里,我们将看到如何使用此8051微控制器将两个8位数字相乘。寄存器A和B将用于乘法。没有其他寄存器可用于乘法。乘法的结果可能超过8位大小。因此,高位字节存储在寄存器B中,低位字节在乘法运算后将存储在累加器A中。 我们在20H和21H位置取两个数字F
本文向大家介绍程序在8051微处理器中减去两个8位数字,包括了程序在8051微处理器中减去两个8位数字的使用技巧和注意事项,需要的朋友参考一下 现在,在本节中,我们将看到如何使用8051微控制器减去两个8位数字。寄存器A(累加器)在操作中用作一个操作数。在不同的寄存器组中有七个寄存器R0 – R7。我们可以将它们中的任何一个用作第二操作数。 我们在位置20H和21H取两个数字73H和BDH,相减后
我是一名编程初学者,并尝试使用处理来实现简单的数据可视化。为了测试,我创建了一个csv文件,其中列出了三列数据,其中第二列和第三列是数字。我分析了这些列,并尝试将第二列数字与第三列数字分开。但不幸的是,结果显示为零。 代码是
本文向大家介绍8085微处理器中的程序计数器(PC),包括了8085微处理器中的程序计数器(PC)的使用技巧和注意事项,需要的朋友参考一下 PC是一个16位寄存器。它包含一个内存地址。PC包含该内存地址,将从该地址中提取下一条指令以执行。假设PC内容为8000H,则意味着8085希望在8000H处获取指令字节。在8000H提取字节后,PC会自动递增1。这种方式8085准备提取指令的下一个字节(如果
本文向大家介绍用于在8085微处理器中从键盘输入2个数字的程序,包括了用于在8085微处理器中从键盘输入2个数字的程序的使用技巧和注意事项,需要的朋友参考一下 我们使用键盘上的两个2位十六进制数字编写了一个8085汇编语言程序,该程序有两个输入,然后在地址字段中相加并输出结果。
本文向大家介绍8085程序将两个16位二进制数相乘,包括了8085程序将两个16位二进制数相乘的使用技巧和注意事项,需要的朋友参考一下 现在让我们看一下Intel 8085微处理器的程序。该程序将计算两个16位数字的乘法。 问题陈述 编写8085汇编语言程序,将两个分别存储在8000H -8001H和8002H-8003H的16位数字相乘。 讨论区 该程序从存储单元8000H – 8001Hand