下面说说程序执行加法时候发生了什么??
这里给出了操作码相应的含义。(真实的指令集是很多的,这里只是模拟一部分)。
假如程序要计算: z = x + y ;
那么编译后的指令初始化(这个指令并不是真实指令):
下面分为三部分:
1.第一步读取X
2.第二步读取Y,相加
3.将结果写入Z所在地址
4.终止程序
这里对应主内存中00地址的运行图:
1.PC初始化 = 0,PC将0地址赋值给MAR,PC + 1。
2.主内存从MAR读出指令地址,将指令地址存储的指令赋值给MDR。
3.IR读取MDR所存储的指令,将指令交给CU,此时操作码对应的是读取操作。
4.IR将操作数地址(即主内存中的04,X的地址)交由MAR。
5.主内存读取MAR的操作数地址,将地址中的操作数赋值给MDR。
6.CU发出信号,将MDR的数值载入寄存器1,此时寄存器1的值 = 3。
这里对应主内存中01的执行流程:
1.此时PC的地址值 = 1,PC将1赋值给MAR, PC + 1
2.主内存从MAR读出指令地址,将指令地址存储的指令赋值给MDR
3.IR读取MDR所存储的指令,将指令交给CU,此时操作码对应的是加法操作
4.IR将操作数地址(即主内存中的05,Y的地址)交由MAR。
5.主内存读取MAR的操作数地址,将地址中的操作数赋值给MDR。
6.CU发出信号,将MDR中的操作数值放进寄存器2,此时寄存器2的值为6
7.CU发出信号,ALU读取寄存器1 和 寄存器2 的值,进行加法运算,并将结果放入寄存器3
这里对应的是主内存中03的操作流程:
1.此时PC = 2,PC将当前地址值赋值给MAR,PC + 1
2.主内存从MAR读出指令地址,将指令地址存储的指令赋值给MDR
3.IR读取MDR所存储的指令,将指令交给CU,此时操作码对应的是写入法操作
4.IR将操作数地址(即主内存中的06,Z的地址)交由MAR
5.CU发出信号,讲寄存器3的数值写入MDR
6.CU发出信号,主内存读取MAR中操作数地址和MDR的操作数值,讲数值写入地址
此时,Z的值为9。
停止流程就是CU检测到IR传递的操作码为停止操作,直接通过中断机制发出信号停止各个硬件之间的交互,中断机制是属于计算机系统部分的知识,而且细分很多种中断,在此不多细说。
乘法可以分解为多个加法操作,只需要编译程序的时候,将加法多次加入主内存即可,但是现代计算机大多数都有优化的乘法运算单元。
至此,加法流程已经结束。
如果有讲解错误,请留言联系作者及时删除,避免引导错误。