热门标签 | HotTags
当前位置:  开发笔记 > 程序员 > 正文

操作系统具有快表的地址变换机构

文章目录局部性原理时间局部性空间局部性什么是快表引入块表后,地址的变换过程小结用一道问题来小结一下快表地址变换机构解答局部性原理如下所示代码,其中i&


文章目录

  • 局部性原理
    • 时间局部性
    • 空间局部性
  • 什么是快表
  • 引入块表后,地址的变换过程
  • 小结
    • 用一道问题来小结一下快表地址变换机构
    • 解答


局部性原理

如下所示代码,其中i,while代码段,他们很可能会被放到内存块的10、23号内存块中,如图2所示
在这里插入图片描述我们不妨假设10号存放的就是while指令,而23号内存块存放的是变量i

在这里插入图片描述


时间局部性

如果执行的某条指令会在不久后被再执行,例如上文中的while()判断,我们就称时间局部性。


空间局部性

而空间局部性也很好理解,我们执行完某条指令后,不久之后,其附近的指令也可能被执行的话,我们就称为空间局部性。


什么是快表

快表又被称为联想寄存器,是一种访问速度比内存快很多的高速缓冲存储器,用于存放之前访问过的页表项。与之对应,我们访问在内存中查找指令页表项信息的页表就称之为慢表。


引入块表后,地址的变换过程

如下图所示,假如我们进程有三条指令,他们都在页号0所对应的内存块中,页内偏移量分别是0、4、8。按顺序执行时,他们会执行如下几个过程:


  1. 首先执行指令1,我们会看到他页号为0,首先和页表寄存器比较一下这这个页号是否超过页表长度,没有超说明合法
  2. 然后查看这个页号在快表中是否存在,若不存在则去内存中查找
  3. 通过页表起始地址+页号*页面长度+便宜量算得物理地址并执行相应指令,然后会将这个页号以及对应的块号地址存入快表中
  4. 由于后续第2条指令、第3条指令都是页号0中,可通过快表直接得到对应内存块的物理地址,配合偏移量即可直接找到这条指令的实际物理地址

在这里插入图片描述


小结


用一道问题来小结一下快表地址变换机构

假如某系统基本分页存储管理采用快表的地址变换机构,访问快表耗时1us,慢表100us。假如快表命中率为90%,那么他们访问物理地址平均耗时是多少呢?


解答

很简单,由题目可知采用的是快表地址变换机构且快表命中率90%,那么快表耗时就是
(1+100)*0.9===>1us快表查询+100us到物理地址捞指令到cpu执行, * 90的概率
(1+100+100)*0.1==>(即一次快表查询没找到 然后去内存找地址100us,再到物理地址中捞指令到cpu执行100us)

把上述相加得到111us,即访问物理地址的平均耗时。


推荐阅读
  • 探讨如何通过编程技术实现100个并发连接,解决线程创建顺序问题,并提供高效的并发测试方案。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • MySQL索引详解与优化
    本文深入探讨了MySQL中的索引机制,包括索引的基本概念、优势与劣势、分类及其实现原理,并详细介绍了索引的使用场景和优化技巧。通过具体示例,帮助读者更好地理解和应用索引以提升数据库性能。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
  • 深入探讨CPU虚拟化与KVM内存管理
    本文详细介绍了现代服务器架构中的CPU虚拟化技术,包括SMP、NUMA和MPP三种多处理器结构,并深入探讨了KVM的内存虚拟化机制。通过对比不同架构的特点和应用场景,帮助读者理解如何选择最适合的架构以优化性能。 ... [详细]
  • 本文将详细介绍如何在Linux操作系统中执行PHP脚本,包括环境配置、命令使用及验证方法。对于需要在Linux环境下开发或部署PHP应用的用户来说,这是一篇非常实用的文章。 ... [详细]
  • 本文探讨了 Spring Boot 应用程序在不同配置下支持的最大并发连接数,重点分析了内置服务器(如 Tomcat、Jetty 和 Undertow)的默认设置及其对性能的影响。 ... [详细]
  • 本文探讨了现代信号处理系统的核心组件,包括数据转换、数据交互和数据处理。详细介绍了AD/DA转换、串/并转换、编解码转换等技术,并讨论了FPGA在信号处理中的应用及其实现方法。 ... [详细]
  • vivo发布iQOO 11系列:搭载骁龙8 Gen2与多项创新技术
    vivo正式推出iQOO 11系列智能手机,该系列搭载最新的高通骁龙8 Gen2处理器,并引入多项创新技术,致力于为用户提供卓越的性能和游戏体验。 ... [详细]
  • 配置Windows操作系统以确保DAW(数字音频工作站)硬件和软件的高效运行可能是一个复杂且令人沮丧的过程。本文提供了一系列专业建议,帮助你优化Windows系统,确保录音和音频处理的流畅性。 ... [详细]
  • 电脑蓝屏故障的成因与解决方案(下)
    本文深入探讨了导致电脑蓝屏的具体原因,并提供了相应的解决方法,帮助用户更好地理解和处理这一常见问题。 ... [详细]
  • 深入解析TCP/IP五层协议
    本文详细介绍了TCP/IP五层协议模型,包括物理层、数据链路层、网络层、传输层和应用层。每层的功能及其相互关系将被逐一解释,帮助读者理解互联网通信的原理。此外,还特别讨论了UDP和TCP协议的特点以及三次握手、四次挥手的过程。 ... [详细]
  • 探索电路与系统的起源与发展
    本文回顾了电路与系统的发展历程,从电的早期发现到现代电子器件的应用。文章不仅涵盖了基础理论和关键发明,还探讨了这一学科对计算机、人工智能及物联网等领域的深远影响。 ... [详细]
  • 在Java中,this是一个引用当前对象的关键字。如何通过this获取并显示其所指向的对象的属性和方法?本文详细解释了this的用法及其背后的原理。 ... [详细]
  • 制程能力分析:Cpk及其相关指数的深入探讨
    本文详细介绍了制程能力指数(Cpk)的概念及其与Cp、Pp、Ppk之间的关系,通过具体案例和图表展示如何评估和改进生产过程的能力。文章还提供了使用Excel和Minitab进行批量计算的实际操作步骤。 ... [详细]
author-avatar
婉里去_
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有