1、存储器
中央处理器(CPU,Central Processing Unit)是一块超大规模的集成电路,是一台计算机的运算核心和控制核心,它的功能主要是解释计算机指令以及处理计算机软件中的数据。指令和数据放在存储器中,也就是我们平时所说的内存,磁盘不同于内存,磁盘中的数据如果不读到内存中,就无法被 CPU 使用。
2、指令和数据
指令和数据是应用上的概念,只是为了方便开发人员区分。在内存和字盘中,指令和数据是没有任何区别的,都是二进制信息。CPU 在工作的时候把有的信息看做指令,有的信息看做数据,为同样的信息赋予了不也一样的意义。
例:内存中的二进制信息 1000100111011000
1000100111011000 --> 89D8H (数据)
1000100111011000 --> mov ax,bx (指令)
3、内存单元
在计算机中最小的信息单位是 bit (比特),也就是一个二进制位,8个 bit 组成一个 Byte,也就是字节。一个存储单元可以存储一个字节,也就是8个二进制位。计算机的存储器容量是以字节为最小单位来计算的,对于一个有128个存储单元的存储器,可以说它的容量为128字节。对于大容量存储器一般还用以下单位来计算容量
1 KB = 1024 B,1 MB = 1024 KB,1 GB = 1024 MB,1 TB = 1024 GB
4、CPU 对存储器的读写
CPU 要从内存中读/写数据,首先要指定存储单元的地址,下面简单的说一下读/写的过程。
例 1 :从 3 号单元中读取数据的过程
(1)CPU 通过地址总线将地址信息 3 发出,找到 3 号单元的位置。
(2)CPU 通过控制总线发出内存读命令。
(3)存储器将 3 号单元中的数据 45 通过地址总线送入 CPU。
例 2 :向 3 号单元中写入数据 78 的过程
(1)CPU 通过地址总线将地址信息 3 发出,找到 3 号单元的位置。
(2)CPU 通过控制总线发出内存写命令。
(3)CPU 通过地址总线将数据 78 送入内存的 3 号单元中 。
5、地址总线
现在我们已经知道 CPU 是通过地址总线来寻找存储器单元的,所以 CPU 可以对多少个存储单元进行寻址是由地址总线来确定的。
假设,一个 CPU 有 10 根地址总线,看一下它的寻址情况,在电子计算机中,一根导线可以传递的稳定状态只有两种,高电平或低电平,用二进制表示成 1 和 0,10 根导线就可以传递 10 位二进制数据,而 10 位二进制数可以表示 2 的 10 次方个不同的数据,最小为 0,最大 1023 。同理,一个 CPU 有 N 根地址线,则我们认为这个 CPU 的地址总线的宽度为 N,最大的寻址范围为 2 的 N 次方。
6、数据总线
CPU 与内存或其他器件之间的数据传送是通过数据总线来进行的,数据总线的宽度决定了 CPU 和外界的数据传送速度,8 根数据线一次可传送一个 8 为二进制数据(一字节)。
7、控制总线
CPU 对外部器件的控制是通过控制总线来进行的,控制总线是一些不同控制线的集合,控制总线的宽度决定了 CPU 对外部器件的控制能力。
8、内存地址空间
内存地址空间的大小受 CPU 地址总线的限制,8086 CPU 的地址总线宽度为 20,可以传送 2 的 20 次方个不同的地址信息,则 8086 PC 的内存地址空间大小为 1 MB。
不同的计算机系统的内存地址空间分配情况是不一样的,下面看一下 8086 PC 机内存地址空间分配的基本情况
向地址 A0000~BFFFF 的内存单元中写入数据,就是向显存中写入数据,会被显卡输出到显示器上,C0000~FFFFF 是只读内存空间,无法进行写操作。