计算机原理 (2) CPU的诞生 输入 输出 PC指针

文章目录

  • 计算机的前世今生
  • 计算机的三个根本性基础
    • 1. 计算机是执行输入、运算、输出的机器;
    • 2.程序是指令和数据的集合;
    • 3.计算机的处理方式有时与人们的思维习惯不同
  • 二、结论
  • 三、参考资料
  • 交个朋友


计算机的前世今生

上一篇文章最终结束的时候谈到希望给大家带来有体系结构的计算机原理的知识,最近翻阅了一些书籍总感觉大家介绍CPU大体上都是按照CPU的组成部分挨个突破,但是又总感觉少了连接的部分,比如DMA这个技术叫直接存储器访问,我们会意识到就是IO与内存之间直接进行数据交换呗,如果直接学习这个概念博主当时没有特别深刻的理解,如果在学DMA之前我们学习CPU是怎么制作的,比如CPU通过读取汇编指令去实现内存与外设之间的数据交换,在这个基础上我们会不会更好的理解DMA呢?
第一篇文章就介绍CPU的诞生,理解一下CPU怎么来的?
在这里插入图片描述

计算机的三个根本性基础

理解一个事物的最好方法就是了解它的原则,什么东西只要找到根子了,就好说了,原则就是根子,理解原则在此基础上我们一点一点的构建一台计算机,这样也可以感觉到计算机的神奇!
计算机的三大原则:

1. 计算机是执行输入、运算、输出的机器;

计算机可以做各种各样的事情,比如:打游戏啦,处理文字啦,绘图啦,浏览网页啦,无论多么复杂的功能,都是以输入、运算、输出这个流程为单位的组合,输入必须有,没有输入计算机又不会自主思考,无法给出输出,运算必须有,没有运算这就是一根导线啊!相当于verilog中的wire a; wire b; assign b = a;这就是直接连线没有任何逻辑的参与,输出也是必要的啊!没有输出咱们用这个计算机也没有任何的意义啦!所有信息就都堆在计算机中了,我们又不能拿来用!从这个角度看自动炒菜机、自动糖葫芦机也符合计算机原则的第一点啊,更宏观的我们与学校结合在一起也可以看成计算机啊,我们是输入,学校有自己的培养流程,最终我们从学校毕业成为了不同的输出!

我们就是最智能的计算机,我们每天通过感官接触海量的信息,经过大脑的思考以后,输出成不同的内容,或者说出来,或者表现在行动上,或者以文章形式记录下来!只有这样我们才可以将自己处理的信息传递给外界!

2.程序是指令和数据的集合;

指令和数据这里涉及到以下几个问题!
1、指令和数据都是二进制数,指令与数据是针对于哪个视角区分的?
指令和数据这两个概念是针对CPU视角阐述的,内存并不区分指令与数据,指令与数据在内存眼里都是二进制数值,正常内存的结构如下:
在这里插入图片描述

正常存储器包括三部分:地址总线、数据总线、读写使能,内存就是给地址,例如给一个读使能,内存就吐出数据,给一个写使能,内存就在相应位置写入数据,内存不在意这个数据是什么,就是一个存数读数,有一个前提条件,这个数据必须是二进制的数据,内存就是一个没有感情的杀手;就好像在我们东北万物皆可冰糖,比如冰糖葫芦,冰糖辣条,冰糖辣椒,不管冰糖啥,反正熬糖浆,包糖,最后冷冻都是这个流程,这就像是内存,就是走这个流程,并不关心走流程的对象是谁!
在这里插入图片描述

指令和数据是针对CPU视角说的,CPU可以从时间和空间上区分指令与数据,CPU之所以区分指令和数据,是因为CPU不能对指令和数据一视同仁,需要对指令与数据进行不同的操作!还是糖葫芦那个例子,冰糖不在乎它包裹了谁,但是咱们在乎啊,吃山楂腹泻的吃冰糖葫芦,那肯定是不行的,可以吃冰糖橘子,冰糖葡萄,就是因为冰糖的对象不同会引发身体不同的感受和反应!下一个问题就是CPU既然区分指令和数据,那它是怎么区分的,区分的依据是什么呢?

2、指令和数据都是二进制数,如何区分指令与数据?
CPU可以从时间和空间上区分数据与指令:
时间上:
在时间上,在取指周期取出的是指令,正常三级流水线的CPU包括三个阶段:取指、译码、执行,在取指周期,CPU会将PC指针的数值作为地址去内存中取出所谓的“指令”,指令经过译码处理以后到达执行阶段,执行周期从内存取出或者往内存中写入的是数据,例如:RISC-V中的数据传输指令lb rd,offset(rs1),从地址为寄存器rs1的值加offset的主存中读一个字节,这个在取指的时候从内存中取出的就是这个数据传输指令,指令经过译码处理以后,进行执行阶段,执行寄存器rs1数值与offset的相加操作得到内存地址,内存地址线得到这个地址,吐出所谓的“数据”。
空间上:
在空间上CPU是如何区分指令和数据的呢?
通过地址来源区分,由PC提供存储单元地址的取出的是指令,指令地址码部分提供存储单元地址的取出的是操作数;
以RISC-V的LW指令为例:
在这里插入图片描述LW(load word)指令格LW rd,offset(rs1) ;
x[rd] = sext ( M [x[rs1] + sext(offset) ] [31:0] )
举个在这里插入图片描述
LW x13,4(x12)
在x12寄存器中的数加上4的偏移量对应的内存地址中,读出四个字节,存到x13寄存器中,其中4(x12)就是LW指令的指令地址码部分,从地址码部分提供的存储单元中取出的就是数据;
在这里插入图片描述
以8086CPU为例,如上图所示,8086中有4个段寄存器:CS、DS、ES、SS,8
086CPU中指令地址是由CS和IP共同提供的
,CS提供段地址,IP提供偏移地址,用它们合成指令的物理地址,去内存中取指令;摘抄王爽老师的汇编语言中的一段话:
如果说,内存中的一段信息曾被CPU执行过的话,那么,它所在的内存单元必然被CS:IP指向过!!!
8086CPU中有一个DS寄存器,通常用来存放要访问数据的段地址;

3.计算机的处理方式有时与人们的思维习惯不同

对计算机什么说什么都是数字!例如我们理解的红色就是一个色彩,但是计算机可能就用"255,0"表示红色;
不论是颜色,还是文字,计算机都是用数字进行表示;

在这里插入图片描述
例如:这张图片我们看到的是天空中有一轮明月,计算机看到的就是一串串数字;
举个例子:Perl脚本中$美元符号就是一个标识符,这个符号的意思就是后面所跟的是一个变量,好比C语言中的int,这就是因为Perl解释器看到美元符号就会把它后面跟的字符当成变量处理,看见C语言中的int则当成普通字符处理,这就是因为Perl解释器和C语言编译器对一个事物的理解不同,当然这种理解是我们人类赋予的!

二、结论

之前说了介绍有体系的计算机原理的文章,这一节介绍了计算机的三大根本性基础,包括以下3点:第1点是计算机是输入、运算、输出的机器,这就好像房子包括房梁、墙、门窗等构成,第2点是程序是由指令和数据组成的,程序是计算机运行的内容,好比房子的用途,比如幼儿园是小孩上学的,菜市场是买菜的地方,第3点是计算机的处理方式与人的思维习惯不同,就好像房子在地产商看来就是钢筋水泥,在我们看来那就是家!

三、参考资料

1.计算机如何区分指令和数据
2.王爽老师:汇编语言
3.计算机是怎样跑起来的

交个朋友

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/300161.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

JavaScript异常处理实战

前言 之前在对公司的前端代码脚本错误进行排查,试图降低 JS Error 的错误量,结合自己之前的经验对这方面内容进行了实践并总结,下面就此谈谈我对前端代码异常监控的一些见解。 本文大致围绕下面几点展开讨论: JS 处理异常的方式…

鸿蒙开发基础运用(ArkTS)-健康生活APP

健康生活应用,主要功能包括: 用户可以创建最多6个健康生活任务(早起,喝水,吃苹果,每日微笑,刷牙,早睡),并设置任务目标、是否开启提醒、提醒时间、每周任务频…

即时战略游戏的AI策略思考

想起来第一次玩RTS游戏,就是框住一大群兵进攻,看他们把对面消灭干净……我接触的第一款游戏是《傲世三国》那会儿是小学,后来高中接触了魔兽地图编辑器,我发现自己喜欢直接看属性而省去争论和试验的步骤——我喜欢能一眼看透的感觉…

Stable Diffusion 系列教程 - 6 Dreambooth及训练

Stable-Diffusion、Imagen等文生图大模型已经具备了强大的生成能力,假设我们的Prompt为 [Cyberpunk Style],SD或许能很快画出赛博朋克风格的一幅画。但你作为一个不知名的人,不能奢求SD在训练的时候把你自己想要的风格也加进去吧?…

李沐-《动手学深度学习-02-目标检测

一 、目标检测算法 1. R-CNN a . 算法步骤 使用启发式搜索算法来选择锚框(选出多个锚框大小可能不一,需要使用Rol pooling)使用预训练好的模型(去掉分类层)对每个锚框进行特征抽取(如VGG,AlexNet…)训练…

C语言中关于函数调用的理解

理论 关于函数调用的方式有两类:传值调用和传址调用 传值调用:函数的形参和实参分别占有不同的内存块,对形参的修改不会影响实参。 传址调用:把函数外部创建变量的内存地址传递给函数参数的一种调用方式。可以让函数和函数外面…

【ThreeJS入门——】WEB 3D可视化技术——threejs

简介 网页上已经可以做出很多复杂的动画,精美的效果。下图就是通过WebGL在网页中绘制高性能的3D图形。 threejs是一个让用户通过javascript入手进入搭建webgl项目的类库。 1、搭建第一个场景和物体 三维的物体要渲染在二维的屏幕上。首先要创建一个场景来放置物体…

源码编译部署篇(二)源码编译milvus成功后如何启动standalone并调试成功!

Milvus启动和调试 0 前言1 Milvus启动【问题描述】出现Aborted问题【问题分析】【解决方法】安装Pulsar服务执行单机启动命令解决监听端口号 2 Milvus调试编写launch.json验证单例调试成功 3 遇到的问题汇总问题1问题2:Permission denied 0 前言 由于Milvus官方文档只提及如何…

【LeetCode:228. 汇总区间 | 区间】

🚀 算法题 🚀 🌲 算法刷题专栏 | 面试必备算法 | 面试高频算法 🍀 🌲 越难的东西,越要努力坚持,因为它具有很高的价值,算法就是这样✨ 🌲 作者简介:硕风和炜,…

FreeRTOS学习第6篇–任务状态挂起恢复删除等操作

目录 FreeRTOS学习第6篇--任务状态挂起恢复删除等操作任务的状态设计实验IRReceiver_Task任务相关代码片段实验现象本文中使用的测试工程 FreeRTOS学习第6篇–任务状态挂起恢复删除等操作 本文目标:学习与使用FreeRTOS中的几项操作,有挂起恢复删除等操作…

探索2024年软件测试的几大主导趋势

进入2024年,考虑影响测试环境的问题至关重要。这种思考将成为团队了解主要瓶颈和实现当今不断提高的期望的首要因素。 01 了解关键测试瓶颈 毋庸置疑,现代团队需要不断创新、适应和拥抱最新趋势,以保持竞争力并提供以客户为中心的解决方案。尽…

OpenGuass 之顺序扫描和索引扫描的代价估算

一. 前言 在OepnGuass中,一条路径的执行代价估算值将直接决定一条路径是否会被取舍。本文主要对OpenGuass中对于普通表的顺序扫描和索引扫描两种路径的的代价估算进行代码走读了解代价估算的整体过程。 二. 顺序扫描代价估算 顺序扫描的路径代价估算在OpenGuass中实…

【C++】- 类和对象(构造函数!析构函数!拷贝构造函数!详解)

类和对象② 类的6个默认成员函数构造函数析构函数拷贝构造函数 类的6个默认成员函数 上一篇详细介绍了类。如果一个类中什么成员都没有,简称为空类。 那么空类中真的什么都没有吗? 并不是,当类在什么都不写时,编译器会自动生成…

Mac 16g约等于Windows多少g?

Mac 16g 内存等于 Windows 320g 内存 何为“黄金内存”? Mac 的内存是用黄金做的,而 Windows 的内存是用铁做的。 黄金的密度是 19.32 g/cm,而铁的密度是 7.874 g/cm。 因此,16g 的黄金体积是 0.082 cm,而 16g 的铁…

CentOS设置docker静态ip

docker容器的ip地址在每次启动后启动顺序设置ip地址,为解决ip地址变动的问题,我们有必要设置docker内部ip地址固定。 第一步先创建一个本地ip地址固定容器的ip docker network create —driver bridge —subnet172.18.12.0/16 —gateway172.18.1.1 wn_d…

XCTF-Misc1 USB键盘流量分析

m0_01 附件是一个USB流量文件 分析 1.键盘流量 USB协议数据部分在Leftover Capture Data域中,数据长度为八个字节,其中键盘击健信息集中在第三个字节中。 usb keyboard映射表:USB协议中HID设备描述符以及键盘按键值对应编码表 2.USB…

【SpringCloud Alibaba笔记】(2)Sentinel实现熔断与限流

Sentinel 概述 官网:https://github.com/alibaba/Sentinel 中文文档:https://sentinelguard.io/zh-cn/docs/introduction.html 类似Hystrix,以流量为切入点,从流量路由、流量控制、流量整形、熔断降级、系统自适应过载保护、热…

w18认证崩溃之暴力破解DVWA

一、实验环境 攻击工具:burpsuite2021.12 靶场:DVWA二、实验目的 演示暴破DVWA的medium和high两个级别,low级别请查看w18认证崩溃之暴力破解4种攻击模式 三、实验步骤 1.设置靶场medium级别 2.开启谷歌代理插件,开启bp拦截&…

多时点DID

标准 DID 模型一般针对政策实施时点为同一个时期,且接受干预的状态将一直持续下去,否则 的交互项设置将会严重违背平行趋势的假设,从而导致交互项的估计系数有偏。由于现实世界中很多的政策试点地区和时间都不尽相同,而且也容易发…

霍兰德职业兴趣测试 60题(免费版)

霍兰德职业兴趣理论从兴趣的角度出发探索职业指导的问题,明确了职业兴趣的人格观念,使得人们对于职业兴趣的认识有了质的变化。在霍兰德职业兴趣理论提出来之前,职业兴趣和职业环境二者分别独立存在,正是霍兰德的总结,…