CPU到底是什么东西?它为什么能够执行数学运算?
CPU到底是什么东西?它为什么能够执行数学运算?
本文地址http://yangjianyong.cn/?p=20转载无需经过作者本人授权
简单的物理电路
先来看一张初中学过的物理电路图:
从图中我们可以看出这是一个简单的串联和并联还有反相器的电路。[注:反相器没有按照标准来画]
图中的 a
和 b
代表着控制电路的开关,通过控制这两个开关的通电状态来控制灯泡的亮
与不亮
。
我们用数字 1
和 0
来表示开关的通电
和断电
的状态表示,1
表示通电
状态,0
表示断电
状态。同样的,我们也用数字 1
和 0
来表示灯泡亮
与不亮
的状态, 1
表示灯泡亮了
,0
表示灯泡不亮
。
那么通过我们学过的物理电路的知识,上图中三个电路,分别有以下三种控制结果:
以上三个表格分别表示就是对应了上图中三个电路通过对开关的控制,进而控制灯泡的亮与否。
别小看了这三个简单的电路控制结果的表格,因为这是现代计算机产生的物理基础。可以说,现代计算机的产生就是由这个演变而来的。一个复杂的 CPU
就是从这么简单的电路演变而来的。至于怎么演变来的,接下来该是英国数学家 乔治·布尔
和美国电子工程师 克劳德·艾尔伍德·香农
登场了。
乔治·布尔
乔治布尔这个数学家发明了两个概念:一个叫集合
,一个叫布尔逻辑
。咱们先来看下集合。有学过数学的都知道在集合中,有存在着三种操作,分别是:交集、并集、差集。如下图所示:
相信从上图中,有解开一部分程序员的疑惑,那就是我们在写代码的过程中,一直用到的 OR / AND / NOT
逻辑操作,到底是从哪里来的。其实我们用的就是这个伟大的数学家提出的这个集合的概念以及三种最基本的运算。从上图中可以看出,第一个就是 并集
的运算,第二个就是 交集
的集合运算,第三个就是 差集
的集合运算。而使用到的符号就是这个数学家发明的:[OR]或、[AND]与、[NOT]非
再来看下 布尔逻辑
。在布尔逻辑中,只使用两个值,一个是 0
,一个是 1
。讲这个布尔逻辑这么简单到底有啥用呢?再来看下一个叫 真值表
的东西,表格如下:
这三个表格到底在表达什么呢?可能细心的童鞋已经发现了。其实以上三个表格,就是实现了布尔逻辑中,0
和 1
之间的交集和并集的运算
那么再细心一点的童鞋又可能发现了。实际上,这三个表格的运算结果,跟上面的前三个电路控制结果的表格就是一样的
也就是说,物理跟数学这两个跨界的学科,找到一个相关联的计算方式。由此奠定了数学运算用物理电路的形式实现了
。这点很重要,因为这里数学跟物理有共通的地方,从而实现了让物理电路从此有了数学计算的能力。至于怎么计算的,克劳德·艾尔伍德·香农
出现了。这个伟大的电子工程师创造了 数字电路设计
这个学科
克劳德·艾尔伍德·香农
克劳德·艾尔伍德·香农
原本是在1932年进入到密歇根大学学习,在这个大学里首次接触到了 乔治·布尔
的理论,后来又进入到了麻省理工学院参与了 微分分析机
的研究工作。微分分析机
是一台机械式的计算机,不要小看这台机械式的计算机,这可是参与了很多重要工程,包括曼哈顿计划,就是造原子弹的,很多计算都是靠这种早期的计算器计算出来的。在这里不得不服咱们国家的科研人员,由于当时的技术封锁,咱们国家的科研人员硬是用算盘敲出的原子弹,真的是硬核到不行的操作。
讲了那么多,那么 克劳德·艾尔伍德·香农
具体的贡献是什么呢。通过上面的长篇讲解我们已经知道了一些东西:电子开关的通断电可以用 1
和 0
来表示;布尔逻辑也是 1
和 0
;电子开关的通断电控制灯泡的亮与否,跟真值表的计算结果是一样的;1
和 0
刚好是二进制。而香农的贡献就是,在原来是机械式的计算机上面,引入了电子控制的方式,可以用电子开关模拟布尔逻辑运算了
至于电路为什么能够实现运算,在这里就不进行其他的解释了。这已经进入到了另一个领域了,叫做《数字电路设计》
题外话
复杂的数学计算怎么通过物理电路实现:既然计算机能够实现简单的1位二进制的加法,那么怎么实现更加复杂的数学运算。这就要感谢数学家。数学家将复杂的数学运算简化到数学上的加法运算【咱们国家的原子弹制造就是将复杂的函数运算用算盘打出来的】。数学家运用各种数学工具,比如傅立叶变换、平方开方微积分等等,将数据的计算都换成了加法计算
也就是说,数学上复杂的运算可以通过各种数学工具简化到加法运算,那么就能通过对电路的设计来实现计算,这也就让计算机有了更加强大的计算能力。
总结:CPU是什么。本质上,CPU就是一堆复杂的电路。而为什么能够实现计算,通过对电路的设计来实现计算的
欢迎来我的博客逛一逛 杨建勇的个人博客http://yangjianyong.cn
CPU到底是什么东西?它为什么能够执行数学运算?的更多相关文章
- Java finally语句到底是在return之前还是之后执行(JVM字节码分析及内部体系结构)?
之前看了一篇关于"Java finally语句到底是在return之前还是之后执行?"这样的博客,看到兴致处,突然博客里的一个测试用例让我产生了疑惑. 测试用例如下: public ...
- 【转】Java finally语句到底是在return之前还是之后执行?
网上有很多人探讨Java中异常捕获机制try...catch...finally块中的finally语句是不是一定会被执行?很多人都说不是,当然他们的回答是正确的,经过试验,至少有两种情况下final ...
- 关于RundownProtect到底是什么东西
RundownProtect这个字段相信只要是读过WRK源码的都会看过这个东西,这个字段在进程和线程的结构中都存在.最典型的例子就是对进程要进行什么操作的时候会先引用这个字段进行加保护,等操作结束后再 ...
- 不懂就问」CPU 到底是怎么识别代码的?
近读到这样一篇文章,从底层硬件角度出发剖析了一下CPU对代码的识别和读取,内容之精彩,读完感觉学到的很多东西瞬间联系起来了,分享给猿们. 首先要开始这个话题要先说一下半导体.啥叫半导体? 半导体其实就 ...
- JS事件处理函数中return false到底是什么东西
在<JS DOM编程艺术>一书中,用return false来阻止事件默认行为,可是js高程3里没有这种用法,那这到底是什么呢. 先看一下知乎的一个解释 就此问题,首先要纠正两个观点: 1 ...
- ESB企业服务总线到底是什么东西呢?
顾名思义,企业服务总线(ESB)就是一条企业架构的总线,所有的企业服务都挂接到该总线上对外公布,企业服务总线负责管理服务目录,解析服务请求者的请求方法.消息格式,并对服务提供者进行寻址,转发服务请求. ...
- php单元测试到底是什么东西呢?
前言: 真正写php代码也有3年时间了,勉强算是一个php程序员, 但是,心底却一直没有底气. 都说测试驱动开发,可我连程序开发中什么是单元测试?这种基本的程序员的素养都 还不是很清楚,痛定思痛,决定 ...
- 这个命令可以看到你的cpu到底集合
cat /proc/cpuinfo |grep processor|awk '{print $3}'|wc -l 改变虚拟机分辨率 xrandr -s 1024x768 -r 60 或 ...
- Java finally语句到底是在return之前还是之后执行?
网上有很多人探讨Java中异常捕获机制try...catch...finally块中的finally语句是不是一定会被执行?很多人都说不是,当然他们的回答是正确的,经过我试验,至少有两种情况下fina ...
随机推荐
- 浅谈C#取消令牌CancellationTokenSource
前言 相信大家在使用C#进行开发的时候,特别是使用异步的场景,多多少少会接触到CancellationTokenSource.看名字就知道它和取消异步任务相关的,而且一看便知大名鼎鼎的Cancella ...
- ant的copy标签使用方法
对于ant里拷贝用的标签的用法,此文(来自 http://electiger.blog.51cto.com/112940/39575 )讲得很好,注意其中黑体字部分,今天被这个问题耽误了20分钟. A ...
- DVWA-全等级暴力破解
之前写了dvwa的sql注入的模块,现在写一下DVWA的其他实验步骤: 环境搭建参考:https://www.freebuf.com/sectool/102661.html DVWA简介 DVWA(D ...
- Docker搭建Svn服务器
一.下载镜像 # 搜索镜像 docker search svn # 下载镜像 docker pull garethflowers/svn-server 二.启动镜像 # 编辑配置文件 vim dock ...
- ReentrantReadWriteLock(读写锁)
为了提高性能,java提供了读写锁, 读锁: 在读的地方使用读锁,可以多个线程同时读. 写锁: 在写的地方使用写锁,只要有一个线程在写,其他线程就必须等待 例子: public static Read ...
- GPRS RTU设备OPC Server接口C# 实现
通过本OPC Server程序接口可为用户提供以OPC标准接口访问远程GPRS/3G/以太网 RTU设备实时数据的方式.从而方便实现GPRS/3G/以太网 RTU设备与组态软件或DCS系统的对接.本程 ...
- mysql自带分区(不修改源码)
SELECT PARTITION_NAME,TABLE_ROWS FROM INFORMATION_SCHEMA.PARTITIONS WHERE TABLE_NAME = 'xw_user_appl ...
- Leaflet 中 删除 一个 标记(Marker)
参考:https://blog.csdn.net/qq_34922009/article/details/81184004 下面是我在Leaflet官方文档所找到的答案 ,希望可以帮助到大家 比如以下 ...
- Qt学习笔记(2)-利用StackWidget实现选项卡式页面
学习笔记第二篇,利用Qt实现选项卡式的页面,效果如图1.1-图1.3所示.程序实现的功能是通过点击状态栏实现不同页面的切换,实际上Qt中自带有Tab选项卡式的控件,本文利用StackWidge实现类似 ...
- web项目中的浏览器行为和服务器行为
package day10.think_about_path; import java.io.IOException; import javax.servlet.ServletException; i ...