408笔记|随笔记录|自用|2

news2024/10/6 1:40:13

文章目录

    • cache和TLB
    • 查找总结

接上篇选择题
在这里插入图片描述
在这里插入图片描述
打开同一个文件共享同一个内存索引结点

在这里插入图片描述


cache和TLB

cache由SRAM组成,TLB通常由相联存储器组成,可以由SRAM组成。
DRAM需要不断刷新,性能比较低。
TLB缺失可以由软件或者硬件处理,cache缺失需要由硬件处理。TLB和cache命中率都与程序局部性有关,缺失之后都需要去访问主存。

cache:CPU和主存之间的缓冲
cache分为一级cache,二级cache,三级cache等等.一级cache与cpu处于同一个指令周期.
Cache Line是cache与DRAM同步的最小单位.
典型的虚拟内存页面大小为4KB,而典型的Cache line通常的大小为32或64字节.
CPU 读/写内存都要通过Cache,如果数据不在Cache中,需要把数据以Cache Line为单位去填充到Cache,即使是读/写一个字节
大部分的cache允许软件在某个区域设置模式,一个区域可能是回写,另一个可能是预取.用户一般不能改变cache的模式, 这些通常由设备驱动程序来控制.
预取通常由软件通过所谓的cache隐函数madvise进行控制.

TLB:地址转换后备缓冲,计算机中用于加速虚拟地址到物理地址转换过程的一个硬件组件。

  • TLB是一个高速缓存,访问速度快于主存。TLB是MMU中的一块高速缓存,也是一种Cache.
  • TLB存放的是页表文件的副本,虚拟地址到物理地址的转换表
  • TLB的主要目的是减少地址转换的开销,提高程序的执行效率
    TLB的内部组成:缓存一般页表的指令页表缓存和数据页表缓存,以及缓存大尺寸页表的对应缓存。
    TLB的刷新:
  • 进程进行上下文切换的时候,需要重新设置CR3寄存器(该寄存器内保存有页目录表物理地址(PDBR地址))运用CR3切换可实现对特定进程内存地址的强制读写操作
  • 但在某些情况下,如使用【相同页表的进程切换】或【普通进程切换到内核线程】时,可以避免刷新TLB。

TLB与Cache的区别
TLB和Cache都是高速缓存,但TLB缓存的是页表数据,而Cache缓存的是实际数据。
TLB的访问速度对于虚拟地址到物理地址的转换至关重要,而Cache的访问速度则对于提高指令和数据的读取速度至关重要。

参考资料
在这里插入图片描述

虚拟存储器由操作系统和硬件共同实现
虚拟存储机制采用[全相联映射]

cache访存过程中存在3种缺失情况

  • TLB缺失:要访问的页面对应的页表项不在TLB中。
  • cache缺失:要访问的页面对应的页表项不在TLB中。
  • 缺页:要访问的页面不在主存中。

在这里插入图片描述
在这里插入图片描述

cache缺失/内存缺页处理机构

  • Cache缺失处理由硬件完成:
  • 缺页处理由软件完成,操作系统通过“缺页异常处理程序”来实现
    • 而TLB缺失既可以用硬件又可以用软件来处理
    • TLB保存的是页表中活跃的部分项目

CPU一次访存操作可能涉及5个地方的访问

  • 虚实地址转换(翻译)部分
    • TLB
    • 页表
    • 硬盘
  • 物理地址到cache映射部分
    • Cache
    • 主存

如果发生缺页,那么中断处理一定在虚实地址转换的环节完成(在cache映射之前)

CPU和cache之间单位是"字",
cache和主存之间单位是"块"
主存和辅存之间单位是"页"(虚拟存储系统中)

CPU与cache(或主存)间信息交互的单位是字,而cache与主存见信息交互的单位是块。当CPU访问的某个字不在cache中时,将该字所在的主存块调入cache,这样CPU下次要访问的字才有可能在cache中


【在写不命中时】,加载相应的低一层中的块到高速缓存(cache)中,然后更新这个高速缓存块,成为写分配法;避开cache,直接把这个字写到主存中,成为非写分配法

写操作时,回写法,全写法【在命中时】使用

指令cache通常比数据cache具有更好的空间局部性,指令流通常是顺序执行的。数据流跳转或随机访问的概率较高。

CPU访存时,先要到cache中查看该主存地址是否在cache中,所以发送的是主存物理地址。只有在虚拟存储器中,CPU发送的才是虚拟地址。
在这里插入图片描述

在这里插入图片描述


1)时间局部性
时间局部性是指被引用过一次的内存位置很可能在不远的将来再被多次引用。一个内存位置被重复引用【循环体中的变量i,sum】

2)空间局部性
空间局部性是指如果一个内存位置被引用了一次,那么程序很可能在不远的将来引用其附近的一个内存位置。【存储空间集中度,数组顺序访问】【指令,数组,向量】

查找总结

参考
@啊哈哈哈哈哈韩

一、线性结构
(一)顺序查找
· 特点:按序依次查找。
· 要求:顺序表和链表都适用,有序表和无序表都适用。
· 平均查找长度(查找成功):ASL成功=(n+1)/2
· 最大查找长度(查找失败):ASL失败=n+1

(二)折半查找
· 特点:查找区域不断二分,查找树是一棵二叉排序树。
· 要求:有序顺序表。
· 平均查找长度(查找成功):ASL成功= l o g 2 ( n + 1 ) − 1 log_2(n+1)-1 log2(n+1)1
· 最大查找长度(查找失败):ASL失败=树高= l o g 2 ( n + 1 ) log_2(n+1) log2(n+1) (向上取整)

(三)分块查找
· 特点:块间有序。
· 要求:顺序表和链表都适用,块间有序。
· 平均查找长度(查找成功):分块查找的平均查找长度为索引查找和块内查找的平均长度之和。设索引查找和块内查找的平均查找长度分别为 L i L_i Li L s L_s LsA,则分块查找的平均查找长度为ASL= L i + L s L_i+L_s Li+Ls

二、树形结构
(一)二叉排序树
· 特点:左子树所有结点值<根结点值<右子树所有结点值,因此对二叉排序树进行中序遍历,可以得到一个递增的有序序列。
· 平均查找长度(查找成功):取决于树高,若是平衡二叉树,则ASL=O( l o g 2 n log_2n log2n),若是单支树,则ASL=O(n)。

(二)平衡二叉树
· 特点:任何结点左右子树高度差不超过1的二叉排序树。
· 平均查找长度(查找成功):ASL=O( l o g 2 n log_{2}n log2n)

(三)红黑树
· 特点:满足红黑性质的二叉排序树。
· 平均查找长度(查找成功):ASL成功=O( l o g 2 n log_{2}n log2n)

关于平衡二叉树和红黑树,详见我的另一篇文章:【408精华知识】平衡二叉树与红黑树的考察

(四)B树与B+树

三、散列结构
(一)散列查找
· 特点:据关键字而直接进行访问的数据结构。也就是说,散列表建立了关键字和存储地址之间的一种直接映射关系。
· 平均查找长度:对同一组关键字,设定相同的散列函数,则不同的处理冲突的方法得到的散列表不同,它们的平均查找长度也不同,需要在求出散列表的基础上计算出查找成功时的平均查找长度和查找不成功的平均查找长度。

参考资料


哈夫曼树
2 n − 1 2n-1 2n1哈夫曼编码叶子结点数=码字数

无向图只要没有权值相等的边,其最小生成树唯一
含有顶点数大于1的强连通分量,【有环】

线索二叉树的线索树是二叉树上空链域个数
2n0+2n0=n0+n1+n2+1=n+1
n个节点总共有2n个指针域,n个结点对应n-1条边,n-1个已经使用的指针域
剩余n+1个空指针域用来作为线索指针


前序是进栈序列,中序是出栈序列


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

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

相关文章

JC系列CAN通信说明

目录 一、CAN协议二、指令格式三、通信接线3.1、一对一通信3.2、组网通信 四、寄存器定义五、指令说明4、读取电源电压5、读取母线电流6、读取实时速度8、读取实时位置10、读取驱动器温度11、读取电机温度12、读取错误信息32、设定电流33、设定速度35、设定绝对位置37、设定相对…

Java-进阶二

ArrayList的源代码分析&#xff08;扩容原理&#xff09; 1 使用空参构造的集合&#xff0c;在底层创建一个容量为0的数组。2 添加第一个元素时&#xff0c;底层会扩容创建一个容量为10的数组。3 存满时会扩容1.5倍。4 如果一次添加多个元素&#xff0c;1.5倍还放不下&#xff…

机器学习/数据分析--用通俗语言讲解时间序列自回归(AR)模型,并用其预测天气,拟合度98%+

时间序列在回归预测的领域的重要性&#xff0c;不言而喻&#xff0c;在数学建模中使用及其频繁&#xff0c;但是你真的了解ARIMA、AR、MA么&#xff1f;ACF图你会看么&#xff1f;&#xff1f; 时间序列数据如何构造&#xff1f;&#xff1f;&#xff1f;&#xff0c;我打过不少…

提升客户满意度,数字化售后工单系统的实施策略

售后工单系统助企业优化运营&#xff0c;提升客户满意度。涵盖技术支持、维修服务、客户反馈管理等应用场景。ZohoDesk凭高效定制成企业首选。未来趋势包括AI、物联网、AR/VR技术集成&#xff0c;提升服务智能化水平。 一、售后工单系统的重要性 售后工单系统是企业用来管理和…

基于Java的GeoTools对Shapefile文件属性信息深度解析

目录 前言 一、Shapefile的属性列表信息 1、属性表格信息 2、属性表格包含的要素 二、GeoTools对属性表格的解析 1、常规解析方法 2、基于dbf文件的属性信息读取 三、总结 前言 ESRI Shapefile&#xff08;shp&#xff09;&#xff0c;或简称shapefile&#xff0c;是美…

SQL优化 - 排序

文章目录 排序和索引降序索引 FilesortORDER BY 顺序问题ORDER BY LIMIT 排序和索引 如果ORDER BY操作使用了索引&#xff0c;那么就可以避免排序操作&#xff0c;因为索引本身就是按索引 key 排好序的。那什么情况下&#xff0c;ORDER BY会走索引呢&#xff1f; 例如&#…

专题十_穷举vs暴搜vs深搜vs回溯vs剪枝_二叉树的深度优先搜索_算法专题详细总结

目录 搜索 vs 深度优先遍历 vs 深度优先搜索 vs 宽度优先遍历 vs 宽度优先搜索 vs 暴搜 1.深度优先遍历 vs 深度优先搜索(dfs) 2.宽度优先遍历 vs 宽度优先搜索(bfs) 2.关系图暴力枚举一遍所有的情况 3.拓展搜索问题全排列 决策树 1. 计算布尔⼆叉树的值&#xff08;medi…

CF2013E Prefix GCD

【题目大意】 给定一个长度为 n n n 的数列 a 1 … n a_{1 \dots n} a1…n​&#xff0c;你可以将 a 1 … n a_{1 \dots n} a1…n​ 按照任意顺序进行重排&#xff0c;使得&#xff1a; ∑ i 1 n gcd ⁡ { a 1 , a 2 , a 3 , … , a n } \sum\limits_{i1}^{n}\gcd\left \{…

10.5学习

1.GateWay GateWay⽬标是取代Netflflix Zuul&#xff0c;它基于Spring5.0SpringBoot2.0WebFlux等技术开发&#xff0c;提供统⼀的路由⽅式&#xff08;反向代理&#xff09;并且基于 Filter(定义过滤器对请求过滤&#xff0c;完成⼀些功能) 链的⽅式提供了⽹关基本的功能&…

探索 Python 虚拟环境的奥秘:virtualenv 的魔法世界

文章目录 探索 Python 虚拟环境的奥秘&#xff1a;virtualenv 的魔法世界背景&#xff1a;为何选择 virtualenv&#xff1f;虚拟环境的守护者&#xff1a;virtualenv 是什么&#xff1f;安装 virtualenv&#xff1a;简单几步&#xff0c;开启隔离之旅掌握 virtualenv 的基本用法…

Relu激活

ReLU&#xff08;Rectified Linear Unit&#xff09;激活函数 是卷积神经网络&#xff08;CNN&#xff09;以及许多深度学习模型中最常用的激活函数之一。它的主要作用是引入非线性&#xff0c;使模型能够学习和表达更复杂的特征。以下是对ReLU激活函数的详细解释。 1. ReLU的…

C语言进阶版第16课—自定义类型:结构体

文章目录 1. 结构体类型的声明和初始化2. 结构体自引用3. 结构体内存对齐3.1 结构体内存对齐规则3.2 修改默认对齐数 4. 结构体传参4. 结构体实现位段5. 位段使用的注意事项 1. 结构体类型的声明和初始化 结构体在使用之前都要对其类型进行声明&#xff0c;关键字是struct&…

15分钟学 Python 第36天 :Python 爬虫入门(二)

Python 爬虫入门&#xff1a;环境准备 在进行Python爬虫的学习和实践之前&#xff0c;首先需要准备好合适的开发环境。本节将详细介绍Python环境的安装、必要库的配置、以及常用工具的使用&#xff0c;为后续的爬虫编写奠定坚实的基础。 1. 环境准备概述 1.1 为什么环境准备…

mp4转gif在线转换怎么转?7个视频转动图方法不容错过!(超简单)

mp4转gif在线转换怎么转&#xff1f;如今&#xff0c;将mp4视频转换为gif动图格式&#xff0c;满足了人们对易于分享和网络传播内容的需求。与mp4视频相比&#xff0c;gif动图文件体积相对较小&#xff0c;几乎所有网络平台都支持这种格式&#xff0c;无需额外安装插件或软件。…

CSID-GAN:基于生成对抗网络的定制风格室内平面设计框架论文阅读

CSID-GAN: A Customized Style Interior Floor Plan Design Framework Based on Generative Adversarial Network 摘要前言II. CSID-GAN METHODA. Overall FrameworkB. Algorithm and Loss Function III. DATASETS AND EVALUATION METRICSA. DatasetsB. Evaluation Metrics IV.…

信息安全工程师(34)访问控制模型

前言 访问控制模型是实现访问控制的基础&#xff0c;不同的访问控制模型提供了不同的访问控制策略和机制&#xff0c;以适应不同的安全需求。 一、自主访问控制模型&#xff08;DAC&#xff09; 定义&#xff1a;指资源的所有者有权决定谁可以访问其资源以及访问的方式。资源的…

如何实现事件流操作

文章目录 1 概念介绍2 使用方法3 示例代码我们在上一章回中介绍了通道相关的内容,本章回中将介绍StreamProvider组件.闲话休提,让我们一起Talk Flutter吧。 1 概念介绍 在Flutter中Stream是经常使用的组件,对该组件的监听可void main() {///让状态栏和程序的appBar融为一体…

macos安装mongodb

文章目录 说明安装和配置安装mongodb配置PATH变量 验证日志及数据存放目录 mac启动和关闭mongodb后台启动失败问题mongodb-compass(GUI) 说明 Homebrew core 列表目前已经将 MongoDB 移除,不再为其提供支持。但是使用国内镜像的brew还是可以安装的&#xff01;这里直接从官网下…

使用 Python 代码连接 PostgreSQL

Python 是一个功能非常强大的编程语言&#xff0c;尤其在与数据库交互时&#xff0c;提供了丰富的解决方案。在实际项目中&#xff0c;我们经常需要通过 Python 连接并操作数据库。为了简化这种操作&#xff0c;ORM&#xff08;对象关系映射&#xff09;框架提供了便利。ORM 能…

aws(学习笔记第一课) AWS CLI,创建ec2 server以及drawio进行aws画图

aws(学习笔记第一课) 使用AWS CLI 学习内容&#xff1a; 使用AWS CLI配置密钥对创建ec2 server使用drawio&#xff08;vscode插件&#xff09;进行AWS的画图 1. 使用AWS CLI 注册AWS账号 AWS是通用的云计算平台&#xff0c;可以提供ec2&#xff0c;vpc&#xff0c;SNS以及clo…