加法流程

下面说说程序执行加法时候发生了什么??

在这里插入图片描述
这里给出了操作码相应的含义。(真实的指令集是很多的,这里只是模拟一部分)

假如程序要计算: z = x + y ;
那么编译后的指令初始化(这个指令并不是真实指令):
在这里插入图片描述
下面分为三部分:
1.第一步读取X
2.第二步读取Y,相加
3.将结果写入Z所在地址
4.终止程序

在这里插入图片描述

这里对应主内存中00地址的运行图:
	1.PC初始化 = 0,PC将0地址赋值给MAR,PC + 12.主内存从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传递的操作码为停止操作,直接通过中断机制发出信号停止各个硬件之间的交互,中断机制是属于计算机系统部分的知识,而且细分很多种中断,在此不多细说。

乘法可以分解为多个加法操作,只需要编译程序的时候,将加法多次加入主内存即可,但是现代计算机大多数都有优化的乘法运算单元。

至此,加法流程已经结束。

如果有讲解错误,请留言联系作者及时删除,避免引导错误。

  • 3
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值