完成一条指令的最多需要四个工作周期:取指周期,间指周期,执行周期,中断周期。
在译码的时候指令中的操作数地址是间接地址,所以就会有一个间址周期用来,将操作数的地址从主存中取出,执行周期执行的是取出操作数并执行相应的操作并把结果保存在给定的寄存器当中
机器是如何区别这四个机器周期呢,可以用触发器,在不同的阶段设置为1进行判断
把对指令的译码也放在了取值周期内,是因为访存很慢,但是对指令的译码是很快的,取出操作数是要在执行周期内执行
流水线方案因为在不同的机器周期机器会占用不同的寄存器,假如一个指令在取指周期对pc占用,其他指令就不可以占用pc只有取指周期,才可以使用,一旦结束取指周期,立马开始下一条指令