【操作系统复习】第6章 虚拟存储器 1

news2024/11/29 0:54:51

前面所介绍的各种存储器管理方式,有一个共同特点作业全部装入内存后方能运行

问题: 大作业装不下 少量作业得以运行

解决办法:

方法一:从物理上增加内存容量,成本高

方法二:从逻辑上扩充内存容量->虚拟存储技术

程序的局部性的应用

1. 部分装入:在程序装入时,不必将其全部读入到内存,而只需将当前需要执行的部分页或段读入到内存,就可让程序开始执行。

2. 请求调页(段):在程序执行过程中,如果需执行的指令或访问的数据尚未在内存(称为缺页或缺段),利用OS提供的请求调页(段)功能,将相应的页或段调入到内存,然后继续执行程序。

3. 置换:如果此时内存已满,无法装入新的页(段),则还必须调用页(段)置换功能。

4. 大作业+多并发:这样,便可使一个大的用户程序,在较小的内存空间运行; 也可在内存中同时装入更多进程并发运行。

虚拟存储器:具有请求调入功能和置换功能,能从逻辑上对内存容量加以扩充的一种存储器系统。

多次性:作业中的程序和数据允许被分成多次调入内存允许

对换性:作业运行时无须常驻内存,允许作业在运行过程中换进换出

虚拟性:从逻辑上扩充了内存容量,使用户看到的内存容量远大于实际内存容量

离散性:在内存分配时采用离散分配方式

实现原理:进程运行只装入部分程序和数据,在外存保留完整副本,运行中动态调整进程在内存中的部署

优点: 利用率高,方便用户,对多道程序运行有较强的支持

实现方式:两种典型虚拟存储器实现方式

 

页式虚拟存储

1. 页式虚拟存储:在分页系统的基础上,增加了请求调页功能、页面置换功能所形成的页式虚拟存储系统

2. 基本思想:分页管理,装入少量页运行,缺页故障后调整

3. 页表结构: 页号+ 标志位+ 块号+ 外存地址

4. 地址转换: 正常地址转换,缺页时产生缺页中断

段式虚拟存储

1. 段式虚拟存储:在分段系统的基础上,增加请求调段及分段置换功能后,所形成的段式虚拟存储

2. 基本思想:装入部分段,动态装入调出

3. 段表结构:段号+ 主存起址+ 长度+ 辅存起址+标志位+扩充位…

4. 缺段中断:缺段时产生缺段中断

5. 地址变换机构:逻辑地址->物理地址,增加缺段中断

请求分页中的硬件支持

请求页表机制

缺页中断机构

在指令执行期间产生和处理中断信号

一条指令在执行期间,可能产生多次缺页中断

地址变换机构

与分页内存管理方式类似

为了实现请求分页,系统要提供一定的硬件支持。除了一定容量的内存和外存,还需要有:页表机制、缺页中断机构和地址变换机构

扩充表(以前页表结构只包含页号和块号两个信息,这是进行地址变换机构所必须的,为了判断页面在不在主存,可在原页表上扩充)

页表机制

用于将用户逻辑地址空间变换为物理地址空间。在页表中增加若干项,以便于标志程序或数据的状态。页表项:

 

状态位(存在位)P:表示该页是否调入内存

访问字段A:用于记录该页在某段时间内被访问的次数

修改位M:表示该页在调入内存后是否被修改过

外存地址:该页在外存上的地址,通常是物理块号

缺页中断机构

缺页中断:在地址映射过程中,在页表中发现所要访问的页不在内存,则产生缺页中断。操作系统接到此中断信号后,就调出缺页中断处理程序,根据页表中给出的外存地址,将该页调入内存,使进程继续运行下去

2. 分配:如果内存中有空闲块,则分配一页,将新调入页装入内存,并修改页表中相应页表项目的状态位及相应的内存块号

3. 淘汰:若此时内存中没有空闲块,则要淘汰某页,若该页在内存期间被修改过,则要将其写回外存

处理过程:保护CPU现场、分析中断原因、转入缺页中断处理程序、恢复CPU环境

特点:缺页中断发生在指令执行期间,而通常情况下,CPU是在一条指令执行完后,才检查是否有中断请求到达;一条指令在执行期间,可能产生多次缺页中断。

 

地址变换机构

1. 在地址变换时,首先检索快表,试图从中找到要访问的页。如找到,修改其访问位。对于“写”指令,还要设置修改位的值。如未找到则转3。

2. 利用页表项中的物理块号和页内地址,形成物理地址。

3. 查找页表,找到页表项后,判断其状态位P,查看该页是否在内存中。如果在,则将该页写入快表(若快表已满,则应该先调出某个或某些页表项)。如果不在,则产生缺页中断,由OS从外存将该页调入内存

请求分页中的内存分配

在为进程分配物理块时,要解决下列的三个问题:

1. 保证进程可正常运行所需要的最少物理块数

2. 每个进程的物理块数,是固定值还是可变值(分配策略)

3. 不同进程所分配的物理块数,是采用平均分配算法还是根据进程的大小按照比例予以分配(分配算法)

内存分配策略

1、固定分配局部置换

思路

– 分配固定数目的内存空间,在整个运行期间都不改变

策略

– 如果缺页,则先从该进程在内存的页面中选中一页,进行换出操作,然后再调入一页

特点

– 为每个进程分配多少页是合适的值难以确定

2、可变分配全局置换

思路

– 每个进程预先分配一定数目的物理块,同时OS也保持一个空闲物理块队列

策略

– 当缺页时,首先将对OS所占有的空闲块进行分配,从而增加了各进程的物理块数。当OS的空闲块全部用完,将引起换出操作

3、可变分配局部置换

思路

– 系统根据缺页率动态调整各进程占有的物理块数目,使其保持在一个比较低的缺页率状态下

特点

– 使大部分进程可以达到比较近似的性能

物理块分配算法

在采用固定分配策略时,可使用下列方法来分配:

1. 平均分配算法:将系统中所有可供分配的物理块,平均分配给各个进程。

2. 按比例分配算法:按照进程的大小比例分配物理块。

3. 考虑优先权的分配算法:为了对于紧迫的作业,能够尽快完成。可以将内存的物理块分成两部分,一部分按比例地分配给各进程;另一部分则根据各进程的优先权,适当增加其相应的份额,分配给各进程。

页面调入策略

何时调入页面

预调页策略:预先调入一些页面到内存

请求调页策略:发现需要访问的页面不在内存时,调入内存

从何处调入页面

如系统拥有足够的对换区空间,全部从对换区调入所需页面

如系统缺少足够的对换区空间,凡是不会被修改的文件,都直接从文件区调入;当换出这些页面时,由于未被修改而不必再将它们重写磁盘,以后再调入时,仍从文件区直接调入

UNIX方式:未运行过的页面,从文件区调入;曾经运行过但又被换出的页面,从对换区调入

① 进程需要的页面不在内存,引起缺页中断

② 中断处理程序保留现场环境,转入缺页中断处理程序

③ 中断处理程序查找页表,得到对应的外存物理块号。如果内存有空闲,则启动磁盘操作,将所缺的页面读入,并修改页表。否则,到4。

④ 执行置换算法,选出要换出的页面,如果该页修改过,应将其写入磁盘,然后将所缺页调入内存,修改相应表项,将其存在位置为‘1’,并放入快表。

⑤ 利用修改后的页表,形成物理地址,访问内存数据。

缺页率

访问页面成功(在内存)的次数为S

访问页面失败(不在内存)的次数为F

总访问次数为A=S+F

缺页率为 f= F/A

影响因素:页面大小、分配内存块的数目、页面置换算法、程序固有属性

缺页中断处理的时间:假设被置换页面被修改的概率是β

 

请求分页存储管理方式

优点:

– 可提供多个大容量的虚拟存储器:作业的地址空间不再受主存大小的限制

– 主存利用率大大提高:作业中不常用的页不会长期驻留在主存,当前运行用不到的信息也不必调入主存

– 能实现多道作业同时运行

– 方便用户:大作业也无须考虑覆盖问题

缺点:

– 缺页中断处理增加系统开销

– 页面的调入调出增加I/O系统的负担

– 此外页表等占用空间且需要管理,存在页内零头

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

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

相关文章

Android Input系统事件分发分析

“本文基于Android13源码,分析Input系统中,事件分发的实现原理“ 整个事件分发到事件的确认过程很长,如果读者只是想大概了解一下,可以直接看末尾总结部分的流程图。 1. 前言 在文章之前,有必要提一下InputReader。其…

创建NAT模式KVM虚拟机

创建NAT模式KVM虚拟机 1 添加脚本执行权限(上传脚本文件至root目录)。 首先需要给脚本赋予执行权限。 # chmod x qemu-ifup-NAT 2 启动虚拟机。 通过命令启动虚拟机。(记得安装net-tools) # yum install net-tools -y # qemu-kvm -m 1024 -drive fi…

注解-Annotation

一. 注解解析 1.1 注释和注解的区别?(掌握) 共同点:都可以对程序进行解释说明。不同点:注释,是给程序员看的。只在Java中有效。在class文件中不存在注释的。当编译之后,会进行注释擦除。 注释…

了解标量、向量和点积

数据科学基础数学:线性代数简介 了解标量、向量和点积 机器只能按着算法理解和处理数据结构存储的数字. 例如创建垃圾邮件检测器,则首先必须将文本数据转换为数字(通过单词嵌入)。 两个句子之间的余弦相似性 两个句子之间的余弦相似性可以通过它们的向量…

【软件相关】Proteus仿真STM32记录

文章目录 0 前期教程1 前言2 先说说建议的流程3 需要注意的事项3.1 供电网配置不要忘了3.2 ADC模块的使用3.3 元器件查询手册 4 一些小技巧 0 前期教程 【软件相关】Proteus 8入门教程 1 前言 最近接了一个项目,是基于Proteus仿真STM32的,虽然此前有听…

软件开发过程中,前期准备的重要性

需求人员,有时候,一开始,并不完全确定自己想要的是什么 因此,值得花费时间,找出他们真正想要的东西 因为,改动的代价,可能代价会是巨大的 构建之前清除一个错误的成本 ( 1 10 ∼ 1 100 ) 开发过…

Mysql 触发器 -> 监控 -> 表 修改前后的 数据 -> 日志

0. 课程视频 https://www.bilibili.com/video/BV1Kr4y1i7ru?p116&spm_id_frompageDriver&vd_sourceff8b7f852278821525f11666b36f180a 1. 简介 1.1 是对象->与表有关 1.2 校验数据完整性 -> 日志记录 1.3 在 insert / update /delete 前后触发 1.4 支持行…

权限提升:Mysql 数据库 .(UDF || 启动项 || 反弹)

权限提升:Mysql 数据库. 权限提升简称提权,由于操作系统都是多用户操作系统,用户之间都有权限控制,比如通过 Web 漏洞拿到的是 Web 进程的权限,往往 Web 服务都是以一个权限很低的账号启动的,因此通过 Web…

〖ChatGPT实践指南 - 零基础扫盲篇⑨〗- OpenAI API 的数据使用政策以及使用限制

文章目录 ⭐ OpenAI API 数据使用政策⭐ 关于 API 数据的一些通用型问题⭐ OpenAI API 数据使用政策的限制 该章节为各位小伙伴介绍以下 OpenAI 的API 数据使用政策,这部分的内容是 OpenAI 官方为我们提供的一份文档,这份文档说明了官方在为我们提供的AP…

Python小姿势 - ## 一、Python多进程编程

一、Python多进程编程 在上一节,我们学习了Python的多线程编程,这节我们学习一下Python的多进程编程。 多进程和多线程比较类似,区别在于多进程是指在一个应用程序中同时运行多个进程,而多线程是指在一个进程中同时运行多个线程。…

ovs-vsctl 命令详解

ovs-vsctl 命令详解 网桥Bridge 创建 Bridge ovs-vsctl add-br br0 删除 Bridge ovs-vsctl del-br br0 列出 Bridge ovs-vsctl list-br 显示详情 ovs-vsctl show 端口 Port 添加端口 ovs-vsctl add-port br0 p1 其中br0 为上面添加的bridge p1可以是物理端口或者vN…

50道web前端工程师面试题及答案解析,你学会了吗

简介:本文包含了50个实用的前端面试题及答案解析,涵盖了HTML、CSS、JavaScript、DOM、Ajax、MVC、模块化、ES6、SPA、Webpack、Babel、Virtual DOM、响应式设计、移动优先设计、响应式图片、CSS 预处理器、后处理器、模块化、布局、盒模型、浮动、定位、…

国民技术N32G430开发笔记(5)- 基本定时器TIM6的使用

基本定时器TIM6的使用 1、设置一个定时器,100ms一次去开关LED灯 2、tim6的初始化代码: 大部分代码来自官方demo /****************************************************************************** Copyright (c) 2019, Nations Technologies Inc.** …

python毕业设计之django+vue专业手语翻译工作室预约管理系统

发起预约:用户选定某翻译员发起预约,进行预约信息填写,主要内容有联系电话、工作方式、场合、时间段;或发起预约,填写预约信息,筛选翻译员,可按关键词筛选或等级筛选。发起预约时间需至少提前服…

从CPU的视角看 多线程代码为什么那么难写!

当我们提到多线程、并发的时候,我们就会回想起各种诡异的bug,比如各种线程安全问题甚至是应用崩溃,而且这些诡异的bug还很难复现。我们不禁发出了灵魂拷问 “为什么代码测试环境运行好好的,一上线就不行了?”。 为了解…

如何将 github pages 迁移到 vercel 上托管

如何将 github pages 迁移到 vercel 上托管 前言 早期网站使用 github pages,后来迁移到 coding,最近又放到腾讯云网站静态托管,无论是 coding 的 cos 存储桶,还是静态网站托管 他们都是收费的,那有没有免费的托管商呢,既不影响网站的访问速度还免费,于是,找了一下,还真有,ve…

电商广告营销中,有哪些常见公式和优化手段

对于电商广告ROI的计算,广泛地应用在二类电商、跨境电商等营销场景中,了解这些相关的投放公式,有助于我们更好地进行广告投放和优化。 特别是针对商家而言,可以指导选品及定价策略、优化最终的广告投放收益,避免出现花…

学系统集成项目管理工程师(中项)系列14_采购管理

1. 概念和术语 1.1. 采购是从项目团队外部获得产品、服务或成果的完整的购买过程 1.2. 三大类 1.2.1. 工程 1.2.2. 产品/货物 1.2.3. 服务 2. 主要过程 2.1. 编制采购管理计划 2.2. 实施采购 2.3. 控制采购 2.4. 结束采购 3. 合同 3.1. 包括买方和卖方之间的法律文…

css布局实战:动态详情九宫格

上篇文件介绍了如何实现九宫格图片展示:css布局入门级实战之九宫格网格布局.不过存在一个问题:图片之间没有间距,用户体验欠佳;基于以上问题,本文进行优化. 较之前实现样式做以下调整:四张图按照两行显示,每行显示三个.不足的显示空白.之前是两行两列显示. 对应九宫格样…

忆暖行动|“他一个人推着老式自行车在厚雪堆的道路上走,车上带着学生考试要用的司机”

忆暖行动|“他一个人推着老式自行车在厚雪堆的道路上走,车上带着学生考试要用的sj” 一头白发,满山青葱 在那斑驳的物件褶皱中,透过泛黄的相片,掩藏着岁月的冲刷和青葱的时光。曾经的青年早已经不复年轻,但是那份热爱…