内存与缓存:保姆级图文详解

embedded/2025/1/20 21:56:03/

文章目录

  • 前言
  • 1、计算机存储设备
    • 1.1、硬盘、内存、缓存
    • 1.2、金字塔结构
    • 1.3、数据流通过程
  • 2、数据结构内存效率
  • 3、数据结构缓存效率

前言

亲爱的家人们,创作很不容易,若对您有帮助的话,请点赞收藏加关注哦,您的关注是我持续创作的动力,谢谢大家!有问题请私信或联系邮箱:fn_kobe@163.com

物理结构在很大程度上决定程序对内存和缓存使用效率,进而影响算法程序整体性能

1、计算机存储设备

1.1、硬盘、内存、缓存

硬盘用于长期存储大量数据,内存用于临时存储程序运行中正在处理数据,而缓存则用于存储经常访问数据和指令,以提高程序运行效率。三者共同协作,确保计算机系统高效运行。
在这里插入图片描述

1.2、金字塔结构

越靠近金字塔顶端的存储设备的速度越快、容量越小、成本越高

①硬盘难以被内存取代
内存中的数据在断电后会丢失,不适合长期存储数据;内存的成本是硬盘的几十倍,消费者市场难以普及。
缓存的大容量和高速度难以兼得
随着 L1、L2、L3 缓存容量逐步增大,其物理尺寸会变大,与 CPU 核心之间物理距离会变远,从而导致数据传输时间增加,元素访问延迟变高。
在这里插入图片描述

1.3、数据流通过程

①过程:在程序运行时,数据会从硬盘中被读取到内存中,供CPU计算使用。缓存可以看作 CPU 的一部分,它通过智能地从内存加载数据,给 CPU 提供高速数据读取,从而显著提升程序执行效率,减少对较慢内存的依赖
在这里插入图片描述

2、数据结构内存效率

在内存空间利用方面,数组和链表各自具有优势和局限性
①内存有限,且同一块内存不能被多个程序共享:数据结构能够尽可能高效地利用空间。数组的元素紧密排列,不需要额外的空间来存储链表节点间的引用(指针),因此空间效率更高。然而,数组需要一次性分配足够连续内存空间,导致内存浪费,数组扩容也需要额外的时间和空间成本。相比之下,链表以“节点”为单位进行动态内存分配和回收,提供更大灵活性
②反复申请与释放内存,空闲内存的碎片化程度会越来越高:导致内存的利用效率降低。数组其连续存储方式,相对不容易导致内存碎片化。相反,链表元素分散存储,在频繁插入与删除操作中,更容易导致内存碎片化

3、数据结构缓存效率

①对比缓存空间容量上远小于内存,但比内存快。缓存容量有限,只能存储一小部分频繁访问数据,当 CPU 尝试访问数据不在缓存中,发生缓存未命中,CPU 从速度较慢的内存中加载所需数据

缓存效率“:缓存未命中”越少,CPU 读写数据的效率就越高,程序性能也就越好

缓存采取数据加载机制
i:缓存缓存缓存行为单位。相比于单个字节的传输,缓存行传输形式更加高效
ii:预取机制:处理器会尝试预测数据访问模式(例如顺序访问、固定步长跳跃访问等),并根据特定模式将数据加载至缓存之中,从而提升命中率。
iii:空间局部性:一个数据被访问,附近数据近期也会被访问
iv:时间局部性:一个数据被访问,不久将来可能再次被访问。

Ps:
①做算法题倾向于选择基于数组实现的栈,提供更高操作效率和随机访问能力,代价仅是需要预先为数组分配一定内存空间。
②如果数据量非常大、动态性很高、栈的预期大小难以估计,基于链表实现栈更加合适。链表能够将大量数据分散存储于内存不同部分,避免数组扩容产生额外开销。


http://www.ppmy.cn/embedded/155593.html

相关文章

20250118面试鸭特训营第26天

更多特训营笔记详见个人主页【面试鸭特训营】专栏 1.说下你常用的 Linux 命令? 文件与目录操作 命令描述ls列出当前目录和文件和子目录ls -l列出当前目录和文件和子目录,包括详细信息ls -a列出当前目录和文件和子目录,包括隐藏文件cd切换目…

微软确认Win10停更不碍Microsoft 365使用!未来是否更新成谜

快科技1月17日消息,微软澄清了关于Windows 10停止支持后Microsoft 365办公套件使用情况的误解。 前两天微软更新支持文档,表示2025年10月14日Windows 10停止支持之后,Microsoft 365应用程序将不再支持Windows 10设备,引发用户担忧…

IoTDB 常见问题 QA 第四期

关于 IoTDB 的 Q & A IoTDB Q&A 第四期来啦!我们将定期汇总我们将定期汇总社区讨论频繁的问题,并展开进行详细回答,通过积累常见问题“小百科”,方便大家使用 IoTDB。 Q1:Java 中如何使用 SSL 连接 IoTDB 问题…

Linux-性能分析top

性能分析top 1. top 命令概述 top 是 Linux 系统中一个常用的性能监控工具,能够动态显示系统的资源使用情况,包括 CPU、内存、进程等信息。通过top命令,用户可以实时查看系统的状态,并进行性能分析,找出资源占用较高…

隧道IP广播与紧急电话系统:提升隧道安全的关键技术

隧道IP广播与紧急电话系统:提升隧道安全的关键技术 随着现代城市交通的迅猛发展,隧道作为重要的交通基础设施,其安全性与应急处理能力显得尤为重要。隧道IP广播与紧急电话系统作为保障隧道安全的关键技术,正发挥着越来越重要的作…

计算机网络 (49)网络安全问题概述

前言 计算机网络安全问题是一个复杂且多维的领域,它涉及到网络系统的硬件、软件以及数据的安全保护,确保这些元素不因偶然的或恶意的原因而遭到破坏、更改或泄露。 一、计算机网络安全的定义 计算机网络安全是指利用网络管理控制和技术措施,保…

ChatGPT大模型极简应用开发-CH1-初识 GPT-4 和 ChatGPT

文章目录 1.1 LLM 概述1.1.1 语言模型和NLP基础1.1.2 Transformer及在LLM中的作用1.1.3 解密 GPT 模型的标记化和预测步骤 1.2 GPT 模型简史:从 GPT-1 到 GPT-41.2.1 GPT11.2.2 GPT21.2.3 GPT-31.2.4 从 GPT-3 到 InstructGPT1.2.5 GPT-3.5、Codex 和 ChatGPT1.2.6 …

“飞的”点外卖,科技新潮流来袭

一、开篇引入 上个周末,阳光正好,我带着孩子去公园游玩。公园里绿草如茵,花朵绽放,孩子们在草地上嬉笑奔跑,好不快活。玩累了,我们便在草坪上的帐篷里休息。 就在这时,天空中突然传来一阵嗡嗡…