如果让你来设计CPU之内存篇

news2025/1/18 8:55:14

哈喽,我是子牙,一个很卷的硬核男人。深入研究Windows内核、Linux内核、Hotspot源码…聚焦做那些大家想学没地方学的课程:手写操作系统、手写虚拟机、手写模拟器、手写编程语言…

目前已经做了两个成熟的课程:手写JVM、手写OS,感兴趣的小伙伴可以加班主任微信咨询:jvm-jingjing

今天想从我们自己设计CPU的角度跟大家聊聊不同时代的CPU是如何管理内存的。我会假定你对此完全不了解,循序渐进的展开。如果你觉得你非常熟悉,那你看看我这篇文章的角度如何?

我会先分享硬件层面的,如CPU、内存条。后面在抽时间分享软件层面的,如Java内存模型、MySQL等中间件的内存池与CPU段页、虚拟内存之间的关系……感兴趣的可以关注我公众号

早期CPU时代

当我们要去创造一个新生事物的时候,我们甚至都不知道它应该长啥样子,所以我们只能把他想得足够简单、设计得足够简单、制作的足够简单…

人类历史上第一代CPU是4位的,意味着它的地址总线,或者说数据总线,亦或者说寄存器宽度只有4位,是不是没概念?那换个说法,这代CPU的最大寻址能力是16字节,即这代CPU支持的最大内存是16字节。你给他1G的内存条,它也只能用16字节。是不是弱爆了?但是它的出现,具有划时代的意义!

地址总线指CPU能识别的最大内存地址宽度,数据总线指CPU一次性读写内存的最大宽度。还不理解的可以自己找资料再看下。这个属于《计算机组成原理》部分的知识

我们平时说的16位CPU、32位CPU、64位CPU,主要指的是CPU内部寄存器的宽度,这个是确定的。即如果是16位CPU,一次最大支持2字节的数据的运算;32位,最大支持4字节的数据运算;64位,最大支持8字节。

比如你想实现这样的运算:0xffffffff + 1,0xffffffff是4字节的,所以32位CPU、64位CPU可一次性运算得出结果,16位CPU就不可以,因为它的寄存器最大宽度是2字节,所以它至少需要经过两次运算才能得到结果

其实除了指寄存器的宽度,我们也可以理解成内部的地址总线、数据总线的宽度。严谨地说,数据总线的宽度与CPU的位数是一致的,地址总线不一定。有的CPU的地址总线超过CPU的位数,比如Intel8086,一款16位的CPU,它的地址总线是20根,最大支持1M寻址。有的CPU的地址总线少于CPU的位数,比如当下x64架构的CPU,地址总线一般是48根。为什么没用64根呢?你可以猜猜看

科技的发展,其一是需求的拉动,其二是自我的成长…显然,4位CPU最大支持内存16字节,8位CPU最大支持内存256字节,都无法满足未来大运算的需求,于是进入了16位CPU时代…

16位CPU时代

理论上来说,16位CPU支持的最大内存是64KB,即2的16次方。但是真正在设计的时候,16位CPU支持的最大内存是1M。是怎么做到的呢?扩展地址总线到20根

这里面就存在一个矛盾:16位CPU的寄存器的宽度是16位,而你支持的最大内存地址是20位,要如何解决呢?

这就说到16位CPU的寻址方式:段基地址+段内偏移。可以这样说,16位CPU奠定了现代CPU的架构基础,因为4位CPU、8位CPU于内存来说,只有页机制。16位CPU引入了段机制,现代的CPU依然是通过段页机制管理内存

举个例子让你更深入理解它的寻址方式,比如读取某个内存位置的值

mov ax, 0x100
mov ds, ax
mov ax, ds:[0x100]

解释下这段代码:

  1. 将0x100赋值给寄存器ax,因为后面要给段寄存器ds赋值,要采用间接赋值的方式,段寄存器中存储的值就是段基地址
  2. 将ax中的0x100赋值给段寄存器ds
  3. CPU执行这句代码要做的事情较多,看图

CPU会先取出段寄存器ds中的值0x100,左移4位,相当于乘以16,得到0x1000,这个就是段基地址,每个段的大小是2的16次方,即64KB。小括号中的0x100就是这个段内的偏移,所以真正访问的物理地址是0x1100

你可能想到一个问题,会不会出现段重叠?答案是:会!如图

第一个段是从0x100 - 0x10100,第二个段是从0x200 - 0x10200,重叠部分是0x200 - 0x10100。重叠会带来什么不好的影响吗?不会。其实你在写操作系统的时候,如果没有规划好,都会出现内存段重叠问题,这个在32位CPU下可能就有影响了,欲知后事如何,关注公众号【硬核子牙】,待我写出文章

显然,16位CPU,最大支持1M内存,性能远远不够,于是进入了超级强大的32位CPU时代…

32位CPU时代

32位CPU,可以说是比较成熟的CPU了,今年你所能看到的CPU机制,在32位CPU中都有了:段页机制、中断机制、虚拟内存、缓存技术、虚拟化……

关于32位CPU,我们讲两点:

  1. 因为32位CPU兼容16位CPU,除了兼容,改进了什么?
  2. 32位CPU引入了保护模式,所以将16位CPU的运行模式称为实模式,包含模式下CPU如何读写内存

在16位CPU中,每次读写内存都要取出段寄存器中的值如0x100,乘以16得到真正的段基地址0x1000,每次运算挺浪费CPU性能的,于是在32位CPU中引入了一个缓存单元:描述符高速缓存器,如图

前面说到,16位CPU,理论上支持的最大内存是64KB,通过扩展地址总线让其支持的最大内存达到1M,真正在寻址的时候将段寄存器中的值左移4位形成真正的段基地址,那32位CPU难道也要才有相同的方式吗?答案是:不可能。

32位CPU引入了全新的段机制,今天的64位CPU依然沿用这套段机制,只是做了些许改变。关于32位CPU的段机制另写文章详细讲解,给大家看个图,先有个了解

最后

想要了解关于操作系统的干货知识,可以看我的以往文章,也可以关注我的公众号,第一时间获取最新干货

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

PPP认证协议详解

PPP认证协议详解 1. 引言 PPP(Point-to-Point Protocol)认证协议在计算机网络中扮演着重要的角色。它是一种用于建立和认证网络连接的协议,广泛应用于各种网络环境,包括互联网接入、虚拟专用网络(VPN)和远…

【头歌】试的学习

1.基本路径测试 2.画出程序控制流图 3.计算流图的环形复杂度 4.确定线性独立路径的基本集合 5.设计测试用例 基本路径测试 除了逻辑覆盖,还有一种常用的白盒测试的测试方法:基本路径测试。基本路径测试是 Tom McCabe提出的一种白盒测试技术。使用这种技…

c++学习——继承

继承 **继承****继承的案例****继承的三种方式方式&#xff1a;****继承中的对象类型****继承中的构造和析构顺序****继承中同名成员的处理****同名静态成员处理****多继承语法****菱形继承** 继承 普通的输出 #define _CRT_SECURE_NO_WARNINGS #include <iostream> us…

8. 让java性能提升的JIT深度解剖

JVM性能调优 1. C1、C2与Graal编译器1.1 C1编译器1.2 C2编译器1.3 分层编译 2. 热点代码3. 热点探测4. 方法调用计数器5. 回边计数器6. 编译优化技术6.1 方法内联 7. 锁消除8. 栈上分配9. 逃逸分析技术10. 标量替换 本文是按照自己的理解进行笔记总结&#xff0c;如有不正确的地…

【LeetCode热题100】打卡第14天:下一个排列最长有效括号

文章目录 【LeetCode热题100】打卡第14天&#xff1a;下一个排列&最长有效括号下一个排列⛅前言&#x1f512;题目&#x1f511;题解 最长有效括号&#x1f512;题目&#x1f511;题解 【LeetCode热题100】打卡第14天&#xff1a;下一个排列&最长有效括号 下一个排列 …

如何入门挖掘SRC?

挖洞其实算是web渗透中第一个明确的关卡 越过这个坎&#xff0c;从此天高任鸟飞&#xff0c;海阔凭鱼跃。越不过&#xff0c;就永远越不过。 先说平台&#xff1a; 漏洞响应平台&#xff1a;实战渗透测试&#xff0c;同时能获得一些外快。 补天漏洞响应平台&#xff1a;http…

Netty核心技术五--Netty高性能架构设计

1. 线程模型基本介绍 不同的线程模式&#xff0c;对程序的性能有很大影响&#xff0c;为了搞清Netty 线程模式&#xff0c;我们来系统的讲解下 各个线程模式&#xff0c; 最后看看Netty 线程模型有什么优越性.目前存在的线程模型有: 传统阻塞 I/O 服务模型Reactor 模式 根据 R…

郭光灿团队实现低温集成量子纠缠光源

中国科大郭光灿院士团队在集成化量子光源制备研究中取得重要进展。该团队任希锋研究组基于低温集成自发四波混频过程&#xff0c;展示了低温条件下集成量子纠缠光源的制备&#xff0c;相关成果于6月2日发表在光学知名学术期刊Optica上。 “利用低温综合四波混合技术产生纠缠现象…

Mapbox表达式详细解读

初学mapbox 的小伙伴们一定会被表达式给弄的晕头转向的。明明条件判断或者回调函数能解决的问题。mapbox里非得让你用表达式。这确实比较ex。 不过我们既然遇到了,也不要怕,这篇文章我就带着大家一点一点的搞明白这个所谓的表达式。 首先从宏观上讲,要知道为什么使用表达式…

【面试高频】cookie、session、token?看完再也不担心被问了

在以往的面试记录里&#xff0c;我又看到了一个多次被问到的知识点&#xff0c;那就是 cookie、session、token 的区别有哪些&#xff1f;如果现在来问你&#xff0c;不知道你能否说清楚呢&#xff1f; 今天不仅仅是整理出这三者的区别&#xff0c;更重要的是能够真正去理解这三…

Python | print写入日志

Python | print写入日志 有时我们需要将屏幕上打印的消息保存到一个文件中&#xff0c;如果每条信息都通过调用写入函数来实现&#xff0c;就太麻烦了 这里自己定义1个日志类&#xff0c;然后将 sys.stdout 设置为该类即可&#xff0c;非常方便 sys.stdout Logger(fileName …

卡尔曼滤波与组合导航原理(八)遗忘滤波

函数模型 { X k Φ k l k − 1 X k − 1 Γ k − 1 W k − 1 Z k H k X k V k \left\{\begin{array}{l} \boldsymbol{X}_{k}\boldsymbol{\Phi}_{k l k-1} \boldsymbol{X}_{k-1}\boldsymbol{\Gamma}_{k-1} \boldsymbol{W}_{k-1} \\ \boldsymbol{Z}_{k}\boldsymbol{H}_{k} \…

C语言:使用 普通方法 和 二分查找算法(折半查找算法) 在一个有序数组中查找具体的某个数字n

题目&#xff1a; 从键盘输入数字n&#xff0c;在一个 有序数组 中查找具体的某个数字n。 思路一&#xff1a;普通方法 &#xff08;逻辑简单&#xff0c;在无序数组中也可以使用&#xff0c;但效率较低&#xff0c;需要逐个查找&#xff09; 总体思路&#xff1a; &#xff…

日常培训管理-参训名单/BootstrapTable获取表数据 / js 删除两个数组中id相同的对象/

---2022.11.9 1、 现在有一个功能是从下面待选名单中选中&#xff0c;再点击这个添加按钮&#xff0c;就会将这些人添加到上面这个参训名单&#xff0c;然后再给其中每个人手动打分。分打完 BootstrapTable中有两组数据&#xff0c;在下面待选名单数据条目前面中打钩选中&am…

从零开始学习CTF——CTF基本概念

这一系列把自己学习的CTF的过程详细写出来&#xff0c;方便大家学习时可以参考。 一、CTF简介 01」简介 中文一般译作夺旗赛&#xff08;对大部分新手也可以叫签到赛&#xff09;&#xff0c;在网络安全领域中指的是网络安全技术人员之间进行技术竞技的一种比赛形式。 CTF…

odoo-028 odoo前端页面显示跟后台数据库内容不一致

文章目录 一、问题二、排查三、总结 版本&#xff1a;odoo13 一、问题 同步多端数据的时候发现&#xff0c;产品product.template页面显示的内容跟用接口查询出来的不一样&#xff0c;接口查询的结果中name值总是后面多一些数据。 页面显示&#xff1a;六甲基二硅胺锂 1.0M T…

开源且免费:全面评估排名前五的缺陷管理工具

软件缺陷管理是一个关于发现&#xff0c;记录&#xff0c;追踪&#xff0c;处理和报告软件缺陷的过程。这是软件开发过程中的一个重要环节&#xff0c;它可以帮助开发团队保持代码的质量并及时修复问题。 一、早期小团队使用的免费缺陷管理工具 在项目早期或者团队规模较小的…

kafka事务(伪事务)

事务要点知识 Kafka的事务控制原理 主要原理&#xff1a; 开始事务-->发送一个ControlBatch消息&#xff08;事务开始&#xff09; 提交事务-->发送一个ControlBatch消息&#xff08;事务提交&#xff09; 放弃事务-->发送一个ControlBatch消息&#xff08;事务终…

瓦坎达的科技真的很厉害吗

就漫威电影宇宙来说&#xff0c;瓦坎达的科技真的很厉害吗 厉不厉害我不敢保证&#xff0c;但是这个IP段的服务器是真的好用 43.241.19.1 43.241.19.2 43.241.19.3 43.241.19.4 43.241.19.5 43.241.19.6 43.241.19.7 43.241.19.8 43.241.19.9 43.241.19.10 43.241.19.11 43.2…

使用ETLCloud强大的自定义规则实现自定义数据处理算法

实时数据处理规则有什么作用&#xff1f; 在大数据中的实时数据采集、ETL批量数据传输过程中很多数据处理过程以及数据质量都希望实时进行处理和检测并把不符合要求的脏数据过滤掉或者进行实时的数据质量告警等。 在数据仓库建设过程中&#xff0c;每家企业的数据处理过程中肯…