微型计算机的工作过程是执行程序过程吗,计算机执行一条程序的过程

基础知识:

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

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

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

d27ff6258920

运算器:图中红色部分,由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”,指令如下:

d27ff6258920

第一步:先看图

d27ff6258920

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

第二步:先看图

d27ff6258920

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

第三步:先看图

d27ff6258920

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

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

d27ff6258920

总结来说就是:

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

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值