5 虚拟存储器

  1. 常规存储器管理方式和局部性原理

    1. 特征:一次性 驻留性
    2. 局部性原理:较短的时间内程序的执行仅局限于某个部分
      1. 时间局限性:最近访问过的又被访问(循环操作)
      2. 空间局限性:程序顺序执行
    3. 虚拟存储器:进程运行时仅部分装入
      1. 虚拟内存 VM:允许进程的执行不必完全在内存中,程序可以比物理内存大
  2. 虚拟存储器

    1. 定义:具有调入功能和置换功能,能从逻辑上对内存容量加以扩充的一种存储系统

    2. 覆盖技术:程序运行过程中,在不同时刻把同一存储区分配给不同程序段或数据段,实现存储区共享的一种内存分配技术。

    3. 交换技术:将内存中某进程暂时不用的程序和数据写入外存交换区中,腾出来的空间供其它进程使用。

      1. 应用:

        1)交换整个作业–用于单道系统(单道模拟多道)

        2)交换整个进程–用于连续分区存储管理(进程挂起、激活、中级调度)

        3)交换页面/段面–用于分页、分段存储管理(虚拟存储技术)

    4. 虚拟存储器的特征

      1. 多次性
      2. 对换性
      3. 虚拟性
    5. 实现虚拟存储器

      1. 分页请求系统:增加请求调页功能和页面置换功能所形成的页式虚拟存储系统 (页面为单位)
      2. 请求分段系统:增加了请求调段功能和分段置换功能所形成的段式虚拟存储系统 (段为单位)
  3. 请求分页存储管理

    1. 硬件支持:请求页表机制 缺页中断机构 地址变换机构

      1. 缺页中断机构
        1. 在指令执行期间产生和处理中断信号,以便能及时将所缺之页面调入内存
        2. 保持多次中断时的状态,保持最后能返回中断前产生中断的指令处继续执行
    2. 数据结构:

      1. 分页存储管理的数据结构:位示图
      2. 请求分页存储管理的数据结构:页表
        1. 将用户地址空间中的逻辑地址映射为内存空间中的物理地址
        2. 记录哪些页面在内存,哪些不在内存
    3. 请求分页中的内存分配

      1. 最小物理块数:保证正常运行所需要的最小物理块数
      2. 请求分页系统中的页面分配应当以减少缺页率为目标
      3. 内存分配策略:
        1. 固定分配局部置换
        2. 可变分配全局置换
        3. 可变分配局部置换
      4. 页面置换:指在内存空间已被装满而又要装入新页时,必须按某种算法将内存中的某页置换为一个新页
    4. 物理块分配算法:

      1. 平均分配法
      2. 按比例分配法
      3. 考虑优先权的分配算法
    5. 页面调入策略:

      1. 随用随调策略/请求调页:发生缺页中断,缺哪页调入哪页
      2. 预调页策略:使用第一页,发生缺页中断,在调入第1页时连同第2、3、…页一起调入
    6. 缺页从哪调入?| 缺页调入时间

      1. 从磁盘对换区中调入缺页(数百us至数十ms)
      2. 从磁盘文件区中调入缺页(几十甚至几百ms)
      3. 从磁盘缓冲区中调入缺页(UNIX方式)(数百ns)
    7. 缺页率:f = F / A (F:访问页面失败的次数 S:访问页面成果的次数 A:A = F + S)

    8. 页面置换算法

      1. OPT 最佳置换算法:被淘汰的页面将是以后永不使用的,或许是在最长时间内不再被访问的页面
      2. FIFO 先进先出置换算法:淘汰最先进入内存的页面
      3. LRU 最近最久未使用置换算法:选择内存中上次使用距当前最远的页予以淘汰
      4. LFU 最少使用置换算法:选择再最近时期使用最少的页面最为淘汰页
      5. CLOCK
      6. 改进的CLOCK
    9. 页面缓冲算法PBA

    10. 抖动

      发生“抖动”的根本原因是,同时在系统中运行的进程太多,由此分配给每一个进程的物理块太少,不能满足进程正常运行的基本要求,致使每个进程在运行时,频繁地出现缺页,必须请求系统将所缺之页调入内存。这会使得在系统中排队等待页面调进/调出的进程数目增加。显然,对磁盘的有效访问时间也随之急剧增加,造成每个进程的大部分时间都用于页面的换进/换出,而几乎不能再去做任何有效的工作,从而导致发生处理机的利用率急剧下降并趋于0的情况。我们称此时的进程是处于“抖动”状态。

      1. 预防方法:
        1. 采取局部置换策略
        2. 把工作集算法融入到处理机调度中
        3. 利用”L = S“准则调节缺页率
        4. 选择暂停的进程
  4. 请求分段存储管理方式

    1. 硬件支持:段表机制、缺段中断机构、地址变换机构
    2. 数据结构:MAT表 段表
    3. 缺段中断机制:进程执行一条指令产生缺段中断时,压入堆栈的断点时当前指令的地址
  5. 请求段页式存储管理

    1. 硬件支持:段表控制寄存器
    2. 软件支持:缺页置换算法

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

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

相关文章

基于ESP32+Platformio的物联网RTOS_SDK-CC_Device

本项目基于ESP32以及Platformio平台开发,请自行查阅如何配置这个环境 开源gitee地址:cc_smart_device 如果愿意贡献项目or提出疑问和修改的,请在gitee上提issue 项目里的mqtt服务器是公共的 请大家最好换成私有的 否则容易收到其他用户的错误…

mybatis 基础入门使用

1、mybatis 简介 1.1、mybatis 特性 MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架; MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集; MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和…

【Java面试】MongoDB

目录 1、mongodb是什么?2、mongodb特点什么是NoSQL数据库?NoSQL和RDBMS有什么区别?在哪些情况下使用和不使用NoSQL数据库?NoSQL数据库有哪些类型?启用备份故障恢复需要多久什么是master或primary什么是secondary或slave系列文章版…

【shell】2、Makefile

文章目录 一、变量1.1 定义简单变量1.2 定义数组1.3 引用变量1.4 规则中定义变量 一、变量 1.1 定义简单变量 用变量名 值的语法来定义变量。这些变量可以用于存储命令、文件名、目录路径等信息,以便在Makefile规则中重复使用 # 定义一个变量 VAR_NAME value# …

Vue练习5:图片的引入

后续会补充 1.require引入 src -> asstes <template><img :src"url"> </template><script> export default {name: App,data(){return{url: require("./assets/logo.png"),}} } </script> 2.import引入 src…

Vue2:Vuex中使用mapState和mapGetters

一、情景说明 前面的Vuex案例中 我们在使用state中的变量或者getter中的变量时 使用插值语法&#xff0c;写法如下&#xff1a; <h1>当前求和为&#xff1a;{{$store.state.sum}}</h1><h1>当前求和放大10倍为&#xff1a;{{$store.getters.bigSum}}</h1&…

【医学大模型】MEDDM LLM-Executable CGT 结构化医学知识: 将临床指导树结构化,便于LLM理解和应用

MEDDM LLM-Executable CGT 结构化医学知识: 将临床指导树结构化&#xff0c;便于LLM理解和应用 提出背景对比传统医学大模型流程步骤临床指导树流程图识别临床决策支持系统 总结解决方案设计数据收集与处理系统实施临床决策支持 提出背景 论文&#xff1a;https://arxiv.org/p…

什么是DoS和DDoS攻击?

DoS和DDoS攻击是两种常见的网络攻击方式&#xff0c;它们通过向目标服务器发送大量的无效或高流量的网络请求&#xff0c;从而耗尽服务器的资源&#xff0c;使其无法正常处理有效的请求。 DoS攻击是一种单点攻击方式&#xff0c;通常是通过向目标服务器发送大量的请求&#x…

【c/c++】C++静态工具类和单例模式对比学习

文章目录 序言1. static静态成员2. C(伪)静态工具类3. 单例模式3.1 单例模式的特点3.2 单例模式的实现方式3.3 单例模式的缺点3.4 Meyer Singleton单例模式 4. (伪)静态工具类 vs 单例模式4.1 区别4.2 如何选择4.3 一些释疑 序言 比较C static&#xff08;伪&#xff09;静态&a…

在k8s中,使用DirectPV CSI作为分布式存储的优缺点

DirectPV 提供了一种直接将物理卷(Physical Volumes)与 Kubernetes 集群中的 Pod 绑定的机制。 利用 DirectPV,你可以将相应的 PV 直接与节点上的物理存储设备(如磁盘)进行绑定,而无需通过网络存储服务(如 NFS 或 Ceph)来提供存储。这种直接访问物理卷的方式,有助于提…

C语言---指针进阶

1.字符指针 int main() {char str1[] "hello world";char str2[] "hello world";const char* str3 "hello world.";const char* str4 "hello world.";if (str3 str4){//常量字符串在内存里面是无法修改的&#xff0c;所以没必要…

springboot/ssm校园菜鸟驿站管理系统Java校园快递取件管理系统

springboot/ssm校园菜鸟驿站管理系统Java校园快递取件管理系统 开发语言&#xff1a;Java 框架&#xff1a;springboot&#xff08;可改ssm&#xff09; vue JDK版本&#xff1a;JDK1.8&#xff08;或11&#xff09; 服务器&#xff1a;tomcat 数据库&#xff1a;mysql 5.…

这是 30 年来创办公司的最佳时机(下篇)

有些很聪明的人没什么成就,主要的原因是不愿意做基础性重复性的工作。 他们有个毛病,一旦达到某个状态,了解了事情的本质,就不愿意再重复去做了。所以,最后她们只能当参谋一样的角色。 真正能做成事情的人,都是能到一线去执行的。要是你聪明、又能干,那成为大才的概率很…

WordPress管理员修改自己用户名的插件Username

有一些站长在刚开搭建WordPress网站时&#xff0c;对于管理员的用户名是随意输入&#xff0c;后来想要修改时发现不懂得如何下手。其实&#xff0c;修改WordPress管理员用户名最快速的方法就是进入数据库直接修改&#xff0c;详见『通过phpMyAdmin直接修改WordPress用户名的图文…

linux 环境下使用gsettings更改alt+tab切屏模式

Linux 操作系统配置 dconf是GNOME3的注册表&#xff0c;可以通过改变dconf中value的值来改变配置&#xff0c;有两种配置方法。第一种是通过可视化GUI dconf-editor进行配置&#xff0c;第二种是通过gsettings command line的方式改变dconf注册表中的value来设置。 dconf-edit…

裸辞5个月,面试了37家公司,终于找到理想工作了

上半年裁员&#xff0c;下半年裸辞&#xff0c;有不少人高呼裸辞后躺平真的好快乐&#xff01;但也有很多人&#xff0c;裸辞后的生活五味杂陈。 面试37次终于找到心仪工作 因为工作压力大、领导PUA等各种原因&#xff0c;今年2月下旬我从一家互联网小厂裸辞&#xff0c;没想…

物联网水域信息化:水质监测智慧云平台

行业背景 由于传统水务企业水质监测和管理技术不足&#xff0c;以及水源污染等问题&#xff0c;确保供水水质达标困难重重。 且传统水务行业信息化手段单一&#xff0c;缺乏对大数据等新技术的应用&#xff0c;一定程度上影响了水务工作的精细化和智能化程度。 系统特点 为…

【plt.pie绘制饼图】:从入门到精通,只需一篇文章!【Matplotlib可视化】

【&#x1f4ca;plt.pie绘制饼图】&#xff1a;从入门到精通&#xff0c;只需一篇文章&#xff01;【Matplotlib可视化】&#xff01; 利用Matplotlib进行数据可视化示例 &#x1f335;文章目录&#x1f335; &#x1f3a8; 一、饼图初探&#xff1a;基本概念与用途&#x1f4a…

Python实现KDJ指标计算:股票技术分析的利器系列(3)

Python实现KDJ指标计算&#xff1a;股票技术分析的利器系列&#xff08;3&#xff09; 介绍算法解释 代码rolling函数介绍计算LLV&#xff08;最低价最小值&#xff09;和HHV&#xff08;最高价最大值&#xff09;计算RSV计算SMA&#xff08;简单移动平均&#xff09; 完整代码…

Linux——信号(1)

在我们使用Linux系统的时候我们经常会使用ctrl c的方式来终止进程&#xff0c;也 会使用kill命令来杀掉进程&#xff0c;评判进程退出的健康程度中也有信号的身影。那 么Linux中的信号到底是什么&#xff1f;今天就由我来介绍Linux中的信号。1. 信号的概念 要了解计算机中的信…