小白是一个程序员,前段时间他学习了计算机组成原理,熟悉了一下计算机的构造,认识了译码器、存储器。了解了运算器的运算方式,下面我们来跟着这位小白一起看一下计算机的组成原理。
说到计算机,就不能不提到美籍科学家冯诺依曼。从20世纪初,物理学和电子学科学家们就在争论制造可以进行数值计算的机器应该采用什么样的结构。人们被十进制这个人类习惯的计数方法所困扰。所以,那时以研制模拟计算机的呼声更为响亮和有力。20世纪30年代中期,美籍科学家冯诺依曼大胆的提出,抛弃十进制,采用二进制作为数字计算机的数制基础。同时,他还说预先编制计算程序,然后由计算机来按照人们事前制定的计算顺序来执行数值计算工作。
不多说了,冯诺依曼计算机的结构长什么样呢?它长这样:
由上图可知,冯诺依曼计算机共有五大部件,分别是,存储器、输入设备、输出设备,运算器和控制器,其中运算器和控制器统称CPU,输入设备和输出设备统称IO,存储器包括内存储器和外存储器。
看这张图是不是觉得很简单,无论从哪个角度讲,炸弹专家都无法从里面得到半点启发,但是,今天,小白收到了一封恐吓信,内容是这样的:
尊敬的冯诺依曼先生,感谢你的发明和创造,让我有机会见识了二十世纪最伟大的科技,不过您发明的东西还有待完善,母亲节刚过,就用这个‘礼物‘让你感受一下自己的罪孽吧。也罢,我是一个灾难预言家,今天下午2点,通往纽约的地铁将会在XX地铁站爆炸,届时,如果不能及时疏散地铁,或者拆除‘礼物‘,那么100m范围将会夷为平地。
小白一看信是写给自己的老师冯诺依曼的,他也不知道这个礼物到底是什么样的,只知道这个礼物是一颗炸弹。
小白拿着信,看了看时间,已经是上午十点,还有四个小时,这个炸弹真的会爆炸吗,为什么会与我的老师有关,我的老师是搞计算机的呀,咋跟炸弹匪徒搞一块去了,小白急匆匆的把信送到了冯诺依曼老师的手上,冯诺依曼老师拿着信,信的内容也让他大惊失色,感慨了一句
我担心的事情还是发生了
小白一脸懵逼,什么担心的事情,老师你在担心什么,对了,炸弹匪徒为什么在信上提到了你,这和计算机有什么关系。
冯诺依曼语重心长的说,虽然没多大关系,但是,如果计算机存储器里面不是二进制数据而是炸弹,那就不好说了,小白焕然大悟,什么?这。。。
最后,通往纽约的地铁并没有在XX地铁站发生灾难,小白作为这次事件的解决者,成功在XX地铁站,找到了那枚炸弹。并及时剪断了炸弹的有效电路,成功的阻止了灾难的发生。
事件后,小白回顾了自己的计算机组成原理知识,他说存储器的结构是这样的
首先,通过地址总线找到需要读写数据的在存储体中的位置,然后通过读写电路控制数据的读出和写入,没错就是这么简单。
那么,如何找到需要读写数据的位置呢,由图可知,存储器从地址总线获得一个地址,这个地址通过译码器和驱动器解析地址,从而找到需要读写数据的具体位置。没错也是这么简单。
小白还说,译码器是这样的
这是一个4位译码器,它可以将一个4位二进制序列转化为一个十进制数,我们知道,这个数在0~15内,由图可知一个(n,2^n)的译码器就像这样的:
首先,高电平用1表示,低电平用零表示
其次,依次将0~15转化为二进制数,是这个样子的
十进制数 | 第四位 | 第三位 | 第二位 | 第一位 |
0 | 0 | 0 | 0 | 0 |
1 | 0 | 0 | 0 | 1 |
2 | 0 | 0 | 1 | 0 |
3 | 0 | 0 | 1 | 1 |
4 | 0 | 1 | 0 | 0 |
5 | 0 | 1 | 0 | 1 |
然后,做一个纵向的表格,是这样子的
位数 | 高电平 | 低电平 |
第一位 | 1,3,5,7,9,11,13,15 | 0,2,4,6,8,10,12,14 |
第二位 | ||
第三位 | ||
第四位 |
最后,连接线路即可
没错,还是怎么简单。
那么,如何解析地址的,小白强调道,地址译码分为行地址译码和列地址译码,地址总线获得的地址是一个二进制序列,假如是一个8位地址,那么再假设行地址4位,列地址4位,那么就可以得到
16*16个地址,也就是256个地址,如果假设行地址5位,列地址3位,那么就可以得到32*8也是258个地址。所以一般的存储体地址个数是一样的,在地址个数一样的情况下,行地址越长,数据的位数也就越长,相应的数据也就越少。
这个满足一个公式,就是
C=2^ M*N,其中C为存储体的容量,M为数据长度,N为数据个数
小白最后留下了这张图
最后告诉大家,我就是那个炸弹匪徒