在进入正题之前,先介绍几个名词
基础概念
1、操作数:操作数并不是什么高深的意思,就是我们执行指令时需要用到的真实的数据,比如1+1中的1(当时这个概念一直模糊了好久……)
2、 几种常见寻址方式:
立即寻址:就是我们的操作数已经包含在指令当中,比如指令1+1,那么这种方式就是立即寻址,说白了,就是能立即拿到我们想要的操作数,根本不需要额外操作
直接寻址:就是指令中包含操作数存在的地址,我们需要根据这个地址的找到操作数
间接寻址:就是地址中包含操作数的地址,有点类似于指针的操作原理。我们的指令中存在一个地址,这个地址处存的是我们操作数的地址,我们需要通过两次寻找找到指定的操作数
寄存器寻址:就是我们的指令中会给出指定寄存器,寄存器中包含我们操作数的地址,我们需要通过寄存器中的地址找到操作数
寄存器间接寻址:类似于间接寻址,只不过地址都存到了寄存器上
CPU执行过程
取指阶段:
CPU取指阶段会通过程序计数器来找到我们的指令所存在的地址,提取该指令,并将PC计数器累加,指向下一条指令的地址
翻译阶段:
CPU取到指令以后,会将指令编译成机器指令,就是我们所说的01的机器码。指令分为两部分组成,一部分是操作符,也就是我们所说的加减乘除运算,另一部分就是我们的操作数,我们要将操作符和操作数都翻译出来,为下一阶段使用
执行阶段:
CPU中的ALU接收到01代码以后,就会开始执行,执行运算操作
回写阶段:
我们通过运算得到的结果会回写到我们指定的地址中存储
循环阶段:
循环进行下一次指令操作
版权声明:本文为m0_53127809原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。