美文网首页每日一篇每日记事本每日一文
计算机执行一条程序的过程

计算机执行一条程序的过程

作者: Spencer手记 | 来源:发表于2016-10-21 21:46 被阅读3213次

    基础知识:

           1)微处理器(Microprocessor,μP,)作为微型计算机(微机,Microcomputer,μC)的中央处理器(CPU)有运算器、控制器、若干寄存器组成。

           2)系统总线(外部总线):是CPU与内存、I/O进行数据交换的通道,包括AB、DB、CB。

           3)1CPU周期=1机器周期=12振荡周期

    运算器:图中红色部分,由ALU(算数逻辑单元)、累加器、寄存器组成。ALU就是做加法/减法的地方,它的操作数来自数据寄存器和累加器,运算得到的结果放在累加器;累加器的作用就是把操作数送给ALU、保存数据ALU计算的结果。总的来说,运算器的功能是执行算术运算、逻辑运算。

    控制器:由程序计数器(PC)、指令寄存器、指令译码器等。其功能有:

    1)从内存中取出指令,并由PC指出下一条指令在内存的位置

    2)对把指令送到指令译码器进行译码,产生相应控制信号,以便执行规定的动作

    3)指挥并控制CPU、内存、I/O设备的之间的数据流动

    几个重要寄存器:

    累加器(A)

    数据寄存器(DR):所有从内存或I/O设备读/写的数据都要先暂存于此,可暂存指令或数据。

    程序计数器(PC):又称指令地址计数器,每次执行指令时,它都会自加1,以指出下一条指令的位置。

    地址寄存器(AR):用于保持CPU要访问的内存或I/O的地址。因为内存、I/O与CPU的速度差距太大,故需要AR暂存地址。假设没有这个寄存器,CPU正在读内存或I/O中的数据,它俩速度太慢,数据还没读完,又来了个新地址指向内存或I/O,则会把前面没读完的数据丢失。

    指令寄存器(IR)、指令译码器(ID):当从内存读取的是指令时,通过数据总线送到DR,然后再送到IR,ID再进行译码,译码后才知道要发出什么具体的的控制信号。

    计算机执行一条程序的过程:

    假设现在要执行“7+10”,指令如下:

    第一步:先看图

    假设程序的初始地址是00010000,则计算机上电后,PC就指向00010000。PC把00010000送给地址寄存器,地址寄存器通过地址总线指向了内存的00010000单元,内存把00010000中的内容10010110送到数据寄存器,因为这个内容是指令,所以又送到指令寄存器、指令译码器,经过译码后,计算机就知道了这个命令是LDA,要装数到累加器,这一步花费了一个机器周期。这时PC已经加1了。

    第二步:先看图

    上面说到PC加1了,于是PC里的数据变为00010001,把00010001送给地址寄存器,地址寄存器通过数据总线指向了内存的00010001单元,找到了其中的数据00010111(23),送到地址译码器。这里花费了一个机器周期。PC又加1,准备好执行ADD 24。

    第三步:先看图

    因为是直接寻址,找到了操作数00010111(23)后,又把它当作地址,指向了内存的00010111位置,取出了其中的数据00000111(7),再通过数据总线传到数据寄存器,数据寄存器又把00000111传到累加器A。这里又花费了一个机器周期。至此,计算机完成了LDA 23。

    再看看执行指令LDA 23 的机器周期是怎样的:

    总结来说就是:

    第一个机器周期完成取操作码、译操作码

    第二个机器周期完成把操作数地址送到译码器

    第三个机器周期完成把操作数地址指定的数据送给数据寄存器

    相关文章

      网友评论

        本文标题:计算机执行一条程序的过程

        本文链接:https://www.haomeiwen.com/subject/lbkquttx.html