操作系统(13)虚拟存储器

前言

       操作系统中的虚拟存储器是一项关键技术,它为用户提供了一个远大于实际物理内存容量的逻辑内存空间。

一、定义与原理

       虚拟存储器是具有请求调入功能和置换功能,能从逻辑上对内存容量加以扩充的存储器系统。其逻辑容量由内存容量与外存容量之和决定,运行速度接近内存,但成本接近于外存。虚拟存储器基于局部性原理构建,该原理指出程序在某段时间内主要访问其地址空间的一部分。

二、功能与作用

  1. 扩大寻址空间:虚拟存储器为用户提供了一个远大于物理内存的虚拟地址空间,使得用户能够运行比物理内存实际容量更大的程序。
  2. 提高开发效率:由于虚拟存储器提供了更大的内存空间,开发者可以更加自由地编写和调试程序,而无需担心内存不足的问题。
  3. 资源优化:虚拟存储器通过自动实现部分装入和部分替换功能,优化了内存资源的利用,使得多个大内存需求的进程能够并发运行。
  4. 内存保护:每个进程都有自己的虚拟地址空间,防止了进程间的非法内存访问,提高了系统的安全性。

三、分类与管理方式

     虚拟存储器主要分为三类:页式虚拟存储器、段式虚拟存储器和段页式虚拟存储器。

  1. 页式虚拟存储器:将主存空间和程序空间都等分成固定大小的页,通过页表实现虚拟地址到物理地址的映射。优点是页内零头小、地址变换快、调入操作简单;缺点是各页不是程序的独立模块,不便于实现程序和数据的保护。
  2. 段式虚拟存储器:按程序的逻辑结构划分地址空间,段的长度是随意的,并且允许伸长。优点是消除了内存零头、易于实现存储保护、便于程序动态装配;缺点是调入操作复杂。
  3. 段页式虚拟存储器:结合了段式和页式的优点,将程序按模块分段,每个段再分成与物理空间页同样小的页面。优点是综合了段式和页式的优点;缺点是增加了硬件成本,软件也较复杂。

四、地址空间与变换

       在虚拟存储器中,存在三种地址空间:虚拟地址空间(程序员编写程序时使用的地址空间)、主存地址空间(存放运行程序和数据的实际内存地址空间)和辅存地址空间(存放暂时不使用的程序和数据的外存地址空间)。

       CPU运行程序访问存储器时给出的地址是虚地址(虚拟地址),首先要进行地址变换。如果要访问的信息在主存中,则根据变换所得的物理地址访问主存;如果要访问的信息不在主存中,则要根据虚地址进行外部地址变换,得到辅存地址,把辅存中相应的数据块送往主存后再访问。

五、页面置换算法

     虚拟存储器中常用的页面置换算法包括:

  1. 随机算法:随机选择一页进行置换。
  2. 先进先出(FIFO)算法:按照页面进入内存的先后顺序进行置换。
  3. 最近最少使用(LRU)算法:选择最近最少被使用的页面进行置换。
  4. 时钟算法:一种近似LRU的算法,通过环形链表和访问位来实现页面的置换。

六、实现与应用

       在不同的操作系统中,虚拟存储器的实现方式可能有所不同。例如,在Windows XP中,采用了分页式的虚拟存储器管理方式;而Linux则支持多种页面大小,并采用了多级页表来减少页表占用的内存空间。此外,虚拟存储器在数据库系统、云计算等领域也有广泛的应用。

总结 

       综上所述,操作系统中的虚拟存储器是一项重要的技术创新,它通过提供远大于实际物理内存容量的逻辑内存空间,有效地解决了物理内存容量有限与程序对内存空间需求不断增长之间的矛盾。

 结语   

自信人生二百年

会当水击三千里

!!!

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

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

相关文章

【实用技能】如何运用Visual Paradigm快速创建团队的项目模板

从 Visual Paradigm 17.2 ()版开始,您可以创建自己的项目模板并与团队共享。这样团队成员就可以轻松创建符合团队标准的新项目。本文将指导您完成为团队创建项目模板的过程。 Visual Paradigm v17.2试用版下载 先决条件 您的团队必须使用 …

不良人系列-复兴数据结构(栈和队列)

个人主页:爱编程的小新☆ 不良人经典语录:“相呴相济 玉汝于成 勿念 心安” 目录 一. 栈(stack) 1. 栈的概念 2. 栈的常见方法 3.栈的模拟实现 ​编辑 二. 队列 1. 队列的概念 2. 队列的使用 2.1 队列的常见方法 2.2 队列的模拟实现 2.3 队列…

【Linux网络】网络基础:IP协议

📝个人主页🌹:Eternity._ ⏩收录专栏⏪:Linux “ 登神长阶 ” 🌹🌹期待您的关注 🌹🌹 ❀ IP协议 IP协议基本概念协议头格式分片与组装网段划分子网掩码特殊的IP地址 IP地址的数量限制…

数据结构——常见数据结构和应用

数据结构是计算机科学中的一个基本概念,它涉及数据的组织、管理和存储方式。以下是对数据结构的详细解释: 一、定义与组成 数据:描述事物的符号记录,是计算机程序的输入和输出。它可以以多种形式存在,如数字、文字、…

Linux正则化与三剑客速成(一)

目录 1.正则化 1.1正则表达式(RE) 1.2 正则表达式的注意事项 1.3正则表达式的分类 1.4 基本正则表达式 ^:表示匹配文本中以某个字符串开头的行。 $:表示匹配以某个字符串结尾的文件内的行 ^$:表示空行,但是在Linux中的实际的操作中一…

HarmonyOS 非线性容器LightWeightMap 常用的几个方法

LightWeightMap可用于存储具有关联关系的key-value键值对集合,存储元素中key值唯一,每个key对应一个value。 LightWeightMap依据泛型定义,采用轻量级结构,初始默认容量大小为8,每次扩容大小为原始容量的两倍。 集合中k…

Docker的容器

目录 1. 什么是容器?2. 容器的生命周期2.1 容器处理OOM事件2.2 容器异常退出2.3 容器暂停 3. 容器命令详解3.1 容器命令清单3.2 docker create命令3.3 docker run命令3.4 docker ps命令3.5 docker logs命令3.6 docker attach命令3.7 docker exec命令3.8 docker stat…

《红队蓝队在网络安全对抗演练中的运作模式》

在网络安全领域,红队与蓝队的对抗性演练是一个复杂且系统的过程,主要包括以下阶段: 一、演练规划阶段 确定目标和范围 组织首先要明确演练的目的,例如测试新部署的网络安全防御系统的有效性、评估员工对网络安全威胁的应对能力或者…

LearnOpenGL学习(高级OpenGL -> 高级GLSL,几何着色器)

完整代码见:zaizai77/Cherno-OpenGL: OpenGL 小白学习之路 高级GLSL 内建变量 顶点着色器 gl_PointSoze : float 输出变量,用于控制渲染 GL_POINTS 型图元时,点的大小。可用于粒子系统。将其设置为 gl_Position.z 时,可以使点…

Excel/VBA 正则表达式归纳汇总

1.with结构。以下语句用来提取A列中的“成品”两个字前面的部分的中文,不含成品两个字,结果存放在第2列。使用了On Error Resume Next,表示错误时继续下一条。 Sub 提取口味() Set regx CreateObject("vbscript.regexp") On Err…

CodeMirror 如何动态更新definemode

CodeMirror 如何动态更新definemode 问题描述:解决方法: 问题描述: 项目中有一部分用到了CodeMirror组件,其高亮显示的内容需要根据最新的json动态的更新,需要使用definemode自定义高亮内容。 想要的效果如下&#xf…

深度与视差的关系及其转换

深度与视差的关系及其转换 在计算机视觉和立体视觉中,深度和视差是两个重要的概念。理解这两者之间的关系对于实现立体图像处理、三维重建以及深度估计至关重要。在这篇博客中,我们将深入探讨深度和视差的概念,并介绍它们之间的转换关系。 …

用户发送请求后服务端i/o工作过程

华子目录 服务端i/o介绍磁盘i/o机械磁盘的寻道时间、旋转延迟和数据传输时间常见的机械磁盘平均寻道时间值常见磁盘的平均延迟时间每秒最大IOPS的计算方法 网络i/o网络I/O处理过程磁盘和网络i/o 一次完整的请求在内部的执行过程 服务端i/o介绍 i/o在计算机中指Input/Output&am…

http的MIME类型

在 HTTP 协议中,MIME 类型(Multipurpose Internet Mail Extensions)用于描述传输内容的类型和格式。MIME 类型通过 Content-Type 头字段来指定,告知客户端如何处理和显示接收到的数据。 常见的 MIME 类型 以下是一些常见的 MIME…

智能人体安全防护:3D 视觉技术原理、系统架构与代码实现剖析

随着工业化程度的提高,生产安全已成为企业关注的重点。尤其是在一些存在禁区的工业厂区和车间,人员误入或违规进入将带来严重的安全隐患。为了解决这一问题,迈尔微视推出了智能人体安全检测解决方案,为企业提供全方位的人员安全监…

sqlalchemy异步方法使用

建立模型 创建基类base.py from sqlalchemy.orm import DeclarativeBaseclass Base(DeclarativeBase):pass以用户为例,建立用户模型继承基类 from sqlalchemy import Integer, String, ForeignKey, DateTime, Boolean from sqlalchemy.orm import mapped_column, Ma…

暂停window11自动更新

window11 的自动更新功能,一方面在后台占用资源,容易导致电脑卡顿;另一方面,“更新并关机” 和 “更新并重启” 的设置令人极其反感。很多补丁兼容性很差,更新后极易引发电脑蓝屏、闪屏等意想不到的 bug。 1.winR打开运…

CTF-WEB: php-Session 文件利用 [第一届国城杯 n0ob_un4er 赛后学习笔记]

step 1 搭建容器 教程 A5rZ 题目 github.com Dockerfile 有点问题,手动修复一下 FROM php:7.2-apacheCOPY ./flag /root COPY ./readflag / COPY ./html/ /var/www/html/ COPY ./php.ini /usr/local/etc/php/php.ini COPY ./readflag /readsecretRUN chmod 755 /var/www…

在Win11系统上安装Android Studio

诸神缄默不语-个人CSDN博文目录 下载地址:https://developer.android.google.cn/studio?hlzh-cn 官方安装教程:https://developer.android.google.cn/studio/install?hlzh-cn 点击Next,默认会同时安装Android Studio和Android虚拟机&#…

网络基础概念

目录 一、计算机网络的发展背景1、网络的定义(1) 独立模式(2)网络互联 2、局域网 LAN3、广域网 WAN4、比较局域网和广域网5、扩展 —— 域域网和互联网 二、初识协议1、协议的概念2、协议的本质3、协议分层(1&#xff…