公司法
当前位置: 首页 法律大全

计算机中存储器的分类和特点(第一章计算机系统概述-第二节)

时间:2023-05-20 作者: 小编 阅读量: 1 栏目名: 法律大全

比如1个数需要用16位二进制代码表示,那么就需要有16个触发器来保存这些代码,这16个触发器就是一个存储单元。许多存储单元共同构成了一个存储体。然后将PC的内容,也就是指令的地址送入到MAR中,即->MAR,MAR=0。也就是说控制器向存储器指明,我接下来要访问主存0号地址处的数据,同时告诉存储器进行读操作23:主存储器会根据MAR记录的地址信息,到存储体中找出0号地址对应的二进制数据,并将其放入到MDR中,此时MDR中存放了第一条指令。

一:计算机层次结构

(1)早期的冯诺依曼机

冯诺依曼机特点如下

  1. 计算机硬件系统由运算器、存储器、控制器、输入和输出设备5部分组成
  2. 指令和数据以同等地位存储在存储器,并可按地址寻访
  3. 指令由操作码和地址码组成,操作码用于表示操作的性质,地址码用于表示操作数在存储器的位置
  4. 指令在存储器内按顺序存放。通常指令是按照顺序存放的,但是在特定条件下可以进行设定
  5. 早期的冯诺依曼机器以运算器为中心,输入输出设备通过运算器与存储器传送数据

其中,实线是数据线,虚线是控制线(双向)。在这种层次结构下,在控制器的指挥下,输入和输出设备输入一些数据给运算器进行各种运算,如果产生中间结果,就会给存储器,计算完成结果给到输出设备。可以发现这种层次结构容易受到输入和输出设备的牵制,因为他们的速度相较于运算器太慢了,也即是短板效应

(2)现代计算机的组织结构

为了解决I/O设备的速度和CPU速度差异悬殊的问题,现如今的计算机则采用以存储器为中心的计算机组织结构

这种结果使I/O操作尽可能绕过CPU,直接在I/O设备和存储器之间完成,以提高系统的整体运行效率

二:计算机硬件概述

(1)存储器

A:存储元、存储单元、存储体、存储字和存储字长

目前我们采用半导体器件来承担存储任务,一个半导体触发器由于有0和1两个状态,就可以记忆一个二进制代码。比如1个数需要用16位二进制代码表示,那么就需要有16个触发器来保存这些代码,这16个触发器就是一个存储单元。

主存储器由许多存储单元组成,每个存储单元包含多个存储元,每个存储元存储1位二进制代码0或1.故存储单元可存储一串二进制代码,称这串代码为存储字,这串代码的位数称为存储字长,存储字长一般是一个字节(8位)或字节的偶数倍。许多存储单元共同构成了一个存储体。

B:存储器的基本结构

存储器分为主存(内存)和辅存(外存)。CPU可以直接访问的是内存,内存主要存放的是程序和数据,是计算机实现“存储程序”控制的基础;外存中信息必须加载进内存后,CPU才可以访问

主存最基本构成如下。存储体存放二进制信息,MAR存放访存地址,经过地址译码后找到所选存储单元;MBR用于暂时存要从存储器中读入或写入的信息

【考点】

  • 数据在存储体中是按照地址存储的,每个地址对应一个存储单元
  • 存储单元数目=2MAR位数
  • ,例如如果MAR为10位,则存储单元数目为210
  • =1024。它用于寻址,其长度和PC长度一致
  • MDR的位数表示存储字长,例如MDR为16,表示存储字长为16,也表示1个字(word)=16bit
  • 注意区分字(word)和字节(Byte),1个字节等于8个bit,而1个字的大小取决于机器
  • 1B=1个字节,1b=1个bit

(2)运算器

运算器是计算机的执行部件,用于进行算数运算和逻辑运算

  • 算数运算:比如加减乘除
  • 逻辑运算:比如与、或、非、异或、比较等等

A:运算器基本结构

其中ALU是运算器造价最为高昂的部分,其实就是一堆复杂的电路

其余三个分别是寄存器,辅助ALU完成计算功能,作用如下了解即可

B:运算器过程伪代码描述

设M为主存中的某一个存储单元,(M)表示取M中的数据,->表示将内容送入寄存器

加法实现:假设ACC中已经存在一个数,那么首先取M的内容送入操作数寄存器X,即(M)->X;然后两者相加重新送入寄存器ACC中,即(ACC) (M)->(ACC)

乘法实现:假设ACC中已经存在一个数,那么首先取M的内容送入乘商寄存器MQ作为乘数,即(M)->MQ,再取ACC寄存器的内容放入X寄存器作为被乘数,即ACC->X,接着将ACC清零,即0->ACC,然后乘数乘以被乘数,一个送入乘积高位,一个送入乘积低位,即(X)×(MQ)->ACC//MQ

除法实现:假设ACC中已经存在一个数,首先取M的内容送入X作为除数,即(M)->X,ACC中的内容作为被除数,结果一个放入MQ作为整数部分,即(ACC)/(X)->MQ,另一个放入ACC作为余数,即(ACC)%(X)->ACC

(3)控制器

控制器是计算机的指挥中心,由其指挥各部件自动协调地进行工作

A:指令

计算机指令就是指挥机器工作的指示和命令,程序本质就是一系列按照一定顺序排列的指令

控制器靠指令指挥机器工作,人们用指令表达自己的意图,并交给控制器执行

指令=操作码 地址码

操作码就是指示计算机要干什么,地址码可以理解为干这些事情需要的原材料在哪里,比如主存中就有可能存储一些我们需要用到的数据,甚至可以是一些IO设备,比如键盘的地址

B:控制器基本结构

控制器基本结构如下

  • 控制单元(CU):分析指令、发出信号、协调操作
  • 指令寄存器(IR):存放当前要执行的指令,注意内容来源于MDR,因为指令和数据一样也被存在存储器
  • 程序计算器(PC):存放当前要执行的指令地址, 与MAR直接连通,并且可以自动 1

C:控制器过程伪代码描述

完成一条指令的过程为:取指令(PC)->分析指令(IR)->执行指令(CU)

具体过程:首先取出指令,即(IR),接着获取指令的操作码,即OP(IR),然后获取指令的地址码,即AD(IR),然后将操作码送入控制单元分析,即OP(IR)->CU,操作码表示需要干什么,但是干活需要原材料,所以再把指令的地址码送入MAR,AD(IR)->MAR,从MAR指示的存储体取出原材料即可。

结合前面的加法,我们可以写出完整的加法运算的过程的: 首要取加法指令,而指令存储在存储体中,想要取出指令必须要知道的指令的地址,而这个地址就存放在PC中,PC又和MAR直接相连,即(PC)->MAR,于是指令此时被放入了MDR中,那么接着将指令放入IR中,即(MDR)->IR,接着取指令的操作码送入控制单元,即OP(IR)->CU,然后再把原材料(就是一些操作数)的地址码送入MAR,即AD(IR)->MAR。接着就可以进行加法操作了,由于上一步已经将操作数的地址码送入了MDR中,所以现在送入操作数寄存器,即(MDR)->X,然后(ACC) (X)->ACC,最后PC要自增,即(PC) 1->PC,表示下一条指令

精华:计算机的工作过程

学习到这里,我们就可以从硬件到角度分析一下,看似简单的C语言代码,在背后计算机究竟做了多少事情

以下程序非常简单,声明了4个变量并赋值,然后在main函数内进行运算

int a=2,b=3,c=1,y=0; void main() { y=a*b c; }

经过编译器编译后,这段程序在主存中就是这样的

  • 下半部分是定义的变量,上半部分则是对应于高级语言对应的机器指令

为了方便演示,我们将控制器、运算器和存储体也放在旁边

第一组

1:程序开始运行,PC的值为0,保存的是第一条指令的地址。然后将PC的内容,也就是指令的地址送入到MAR中,即(PC)->MAR,MAR=0。也就是说控制器向存储器指明,我接下来要访问主存0号地址处的数据,同时告诉存储器进行读操作

2 3:主存储器会根据MAR记录的地址信息,到存储体中找出0号地址对应的二进制数据,并将其放入到MDR中,此时MDR中存放了第一条指令。即M(MAR)->MDR,此时MDR=000001 0000000101

4:接着将MDR中的指令放入IR中,于是控制器就存放了当前要执行的指令。即(MDR)->IR,(IR)=000001 0000000101

5:这条指令的前6个比特位是地址码,会被送入到控制单元CU中,CU分析后,得知这是一条取数命令。即OP(IR)->CU

6:取数指令会将变量a的内容放入寄存器ACC中。但是现在变量a不知道在哪里,所以现在会把指令的地址码送到MAR当中,即(MAR)=5

7 8:接着主存储器根据MAR指明的地址,也就是a的地址(5),去存储体中找出5号地址的数据,并将其放入MDR当中。即M(MAR)->MDR,(MDR)=0000000000000010,也即(MDR)=2

9:接着在控制单元的指挥下,MDR中的数据就被放入到了ACC中。至此第一条指令完成

10:最后PC自增1,进行下一条指令,即(PC)=1

接下来进行下一组操作

1:程序接着运行,PC的值为1,保存的是第二条指令的地址。然后将PC的内容,也就是指令的地址送入到MAR中,即(PC)->MAR,MAR=1。也就是说控制器向存储器指明,我接下来要访问主存1号地址处的数据,同时告诉存储器进行读操作

2 3:主存储器会根据MAR记录的地址信息,到存储体中找出1号地址对应的二进制数据,并将其放入到MDR中,此时MDR中存放了第二条指令。即M(MAR)->MDR,此时MDR=000100 0000000110

4:接着将MDR中的指令放入IR中,于是控制器就存放了当前要执行的指令。即(MDR)->IR,(IR)=000100 0000000110

5:这条指令的前6个比特位是地址码,会被送入到控制单元CU中,CU分析后,得知这是一条乘法命令。即OP(IR)->CU

6:接着把指令的地址码送到MAR当中,即(MAR)=6

7 8:接着主存储器根据MAR指明的地址,也就是b的地址(6),去存储体中找出6号地址的数据,并将其放入MDR当中。即M(MAR)->MDR,(MDR)=0000000000000011,也即(MDR)=3

9:由于是乘法,所以控制单元将MDR中的内容送入到乘商寄存器MQ中,即(MDR)->MQ,此时(MQ)=0000000000000011=3

10:先把a的值放入通用寄存器X中,即(ACC)->X,(X)=2

11:CU告诉ALU,让其进行乘法运算。即(MQ)×(X)->ACC,(ACC)=6。注意如果乘积过大,需要MQ辅助存储,也就是最上面讲到过的(X)×(MQ)->ACC//MQ

接着进行下一组操作,具体过程就不详细演示了,步骤如下

  • 1:PC存储2号指令的地址,(PC)->MAR,(MAR)=2
  • 2 3:M(MAR)->MDR,(MDR)=000011 0000000111
  • 4:(MDR)->IR,(IR)=000011 0000000111
  • 5:OP(IR)->CU,CU分析操作码,得知这是加法执行
  • 6:Ad(IR)->MAR,将指令的地址码送入MAR,(MAR)=7
  • 7 8:M(MAR)->MDR,(MDR)=00000000 00000001=1
  • 9:(MDR)->x,(X)= 00000000 00000001=1
  • 10:(ACC) (X)->ACC,(ACC)->7,由ALU实现加法运算

接着进行下一组操作

  • 1:(PC)->MAR,(MAR)=3
  • 2 3:M(MAR)->MDR,MDR=000010 0000001000
  • 4:(MDR)->IR,(IR)000010 0000001000
  • 5:OP(IR)->CU,CU分析得知,这是存数指令
  • 6:AD(IR)->MAR,(MAR)=8
  • 7 8:(ACC)->MDR,MDR=7
  • 9:(MDR)->地址为8的存储单元,导致y=7

最后再读取到停机指令时,计算机通过中断机制就结束了程序的运行

    推荐阅读
  • 大葱放进冰箱的储存方法(大葱如何储存)

    大葱放进冰箱的储存方法?这样保存的大葱是最常规的,放大半个月大葱是不会空心干枯的。土埋保存法可以直接将大葱的根须埋在土里,大约10厘米左右,土要湿润一些,模拟大葱的生长环境,吃的时候随时拔出来一颗,这样可以保存几个月之久大葱也非常新鲜。

  • 梭子蟹烧熟能放多久 梭子蟹多久能煮熟

    2、梭子蟹中含有丰富的蛋白质成分,而且又经过了油盐的烹饪,因此在一定温度条件下,很容易滋生细菌而变质,若是将烧熟的梭子蟹直接置于常温下存放,一般在只能保存6-8小时左右;3、若是将其置于冰箱保存,一般保存时间相对会长一些,但是也不宜超过一天,烧熟的梭子蟹保存时间越长,其鲜味越差,所以一般建议梭子蟹最好是现做现吃,尽量不要留到下一顿。

  • 南昌大学是国内双一流建设高校么(南昌大学入选部省合建)

    日前,教育部召开支持和提升中西部高等教育发展座谈会,部署启动部省合建工作。陈宝生表示,支持举措要体现合力,在不改变现有隶属关系和管理体制基础上,发挥部、省、校和支援方的作用。还要选优配强合建高校领导班子,将合建高校领导班子成员、校级后备干部列入直属高校干部培训计划。期待南昌大学发挥辐射带动作用我省有教育界人士表示,南昌大学作为我省唯一的211高校,此次入选“部省合建”高校是实至名归。

  • 直角锐角平角钝角之间的区别于联系是什么(直角锐角平角钝角之间的区别于联系是啥)

    接下来我们就一起去研究一下吧!等于180度的角是平角,大于90度小于180度的角是钝角。锐角、直角、钝角是对大于0°并且小于180°的角的一个分类,锐角、直角、钝角间的区别在于角的大小不同。

  • 极端危害环境是指(极端危害环境是指什么)

    极端危害环境是指极端危害环境是指在低温、高碱、高盐、高压、缺水等极其不适合生物生长的环境。而在这种恶劣贫瘠的极端环境中还能够很好地生活的微生物被称为极端微生物,这些极端微生物代表着生命活动的极限。大多数电子产品设计要求参数当中都有要求在极端环境下产品能够正常工作。极端温度极端温度是指产品工作的环境最高和最低温度范围。通常室温认为是25度。

  • 布面鼠标垫属于什么垃圾(布面鼠标垫属于哪些垃圾)

    以下内容希望对你有帮助!布面鼠标垫属于什么垃圾布面鼠标垫属于可回收垃圾可回收垃圾就是可以再生循环的垃圾。本身或材质可再利用的纸类、硬纸板、玻璃、塑料、金属、人造合成材料包装等,与这些材质有关的如:报纸、杂志、广告单及其它干净的纸类等皆可回收。另外包装上有绿色标章是属于要付费的双系统,属于可回收垃圾。

  • 民间谚语大全实用又有趣( 百姓民间气象谚语民谣大全)

    每月两节日期定,最多相差一两天,上半年来六甘一,下半年是八甘三。按照公历来推算,每月两气不改变。抓紧季节忙生产,种收及时保丰年。常刮西北风,近日天气晴。无风起横浪,三天台风降。当阴雨天气来临时,云层比较低,云底盖住山顶。乌头风白头雨“乌头”与“白头”是指两种云的云顶颜色来说的。卷积云一般出现在五千米以上的高空,形成后只能维持几分钟到一个多小时。出现这种云,表明地上空有低压槽移近。

  • 春季角膜炎一般几天好(春季角膜炎频发)

    角膜炎症必然使视力或多或少地受到影响,尤以炎症侵犯瞳孔区域者更为严重。角膜炎的发病症状一、外伤与感染角膜炎有哪些危害1、前房积脓严重病例多合并有虹膜睫状体炎。对各种原因引起的角膜上皮损伤或角膜溃疡,原则上禁用皮质类固醇,以免促使溃疡恶化,或延缓上皮损伤的愈合。角膜炎因角膜外伤,细菌及病毒侵入角膜引起的炎症。

  • 家居旺财的风水方法有哪些(家居旺财的风水方法介绍)

    家居旺财的风水方法有哪些门内是一处不可忽视旺财宝地,门口的玄关处是藏风聚气之地。厨房在风水中有财库说法,主掌内财运。因此,这些地方不能为空,要时时有食品;而且炉灶后方不宜空旷,以免影响财运。一般而言,在客厅大门对角45度位置,正是所谓的“明财位”。葫芦代表福禄,在财位摆放葫芦,旺财效果很显著;或悬挂一个葫芦,对提升财运也很有帮助。

  • 羊水少的原因(孕妇羊水少是什么原因引起的)

    胎儿畸形导致羊水少如果在孕早期或者中期发现羊水过少,则可能是因为宝宝有缺陷,导致不能产生足够的尿液来维持羊水循环。宝宝缺氧导致羊水少慢性缺氧会导致胎儿在子宫内发育迟缓,引起胎儿血液循环重分配,使血液主要供应脑和心脏,导致肾血流量下降,胎尿生成减少而致羊水过少。所以有人认为有些原因不明的羊水过少可能与羊膜本身病变有关。