<Linux>(极简关键、省时省力)《Linux操作系统原理分析之存储管理(1)》(14)

@[TOC](《Linux操作系统原理分析之存储管理》(14)

  • 5 存储管理
    • 5.1 存储管理的目的和功能
      • 5.1.1 存储管理目的:
      • 5.1.2 存储管理的主要功能
      • 5.1.3 存储管理主要是对用户区进行管理
    • 5.2 地址重定位
      • 5.2.1 作业的地址空间
      • 5.2.2.地址映射(重定位)
    • 5.3 分区存储管理
      • 5.3.1 固定分区管理
        • 1.基本思想
        • 2.分区说明表:PDT
        • 3 分配策略
        • 4.优、缺点
      • 5.3.2 可变分区管理
        • 1.基本思想(量体裁衣)
        • 2.与固定分区的区别
        • 3. 主存占有表和空闲说明表(链)
        • 4. 分配策略:主要问题:分配、回收
      • 5.3.3 分区管理存储保护

5 存储管理

5.1 存储管理的目的和功能

5.1.1 存储管理目的:

1) 为多道程序的并发执行提供良好的环境,时每道程序都能在不受干扰的环境中运行。
2)便于用户使用存储器,是用户从存储器的分配、保护和共享等繁琐的事务中解脱出来。
3) 提高存储器的利用率,以提高系统的吞吐量。
4)从逻辑上扩充内存空间,可是大的程序能在小的内存空间运行或允许更多的程序并发执行。

5.1.2 存储管理的主要功能

主存储器的存储空间一般分为两部分:

系统区:用于存放操作系统的程序和数据;
用户区:用于存放应用程序与用户的程序和数据。

5.1.3 存储管理主要是对用户区进行管理

1) 内存分配

a. 为每道程序分配内存空间,使他们“各得其所”
b. 提高存储器的利用率,以减少不可用的存储空间。(即“零头”)
c. 允许正在运行的程序申请附加内存空间,以适应程序或数据动态增长的需求。

为此存储分配机制应具有以下功能:

(1) 记录每个存储区(分配单位)的状态,作为内存分配的依据 (2) 能动态的分配内存:指在进程运行期间,根据系统或用户的请求,分配其所需要的内存空间,并修改相应的空闲存储区表。
(3)及时回收系统或用户进程释放的存储区。

2) 内存保护

内存保护的任务是确保每道程序都在自己的内存空间运行,互不干扰,为此系统需要每道程序 都能:
a. 不访问 os 的任何部分,包括程序区或数据区
b. 执行中的进程不会转移到其他进程的程序中去执行。
c.未经特殊安排,不能访问其他进程中的数据,若在执行中发生了上述情况,系统应能 立即抛弃这样的指令。上述检查需要硬件完成,使用软件不仅会显著增减 cpu 开销,且大大 降低了进程的运行速度。

3) 内存共享
4) 地址映射(讲述作业从源程序到装入的过程)
5) 内存扩充

内存扩充的任务是从逻辑上来扩充内存容量,是用户认为系统所拥有的内存空间比实际的空间大。为实现此任务,系统必须具有下述功能:
a. 请求调入功能
b. 置换功能 虚拟存储器——os
把主存和辅存两者融为一体,为用户提供一个超过实际主存容量的存储器。其容量由计算机的地质结构来决定。

5.2 地址重定位

5.2.1 作业的地址空间

名字空间:用户在使用汇编语言或高级语言编制作业的源程序时,一般要使用符号名来指定程序转移的目的地、子程序的入口地址以及要访问的数据等在作业中的位置。因此这个作业空间称为名字空间。

作业的逻辑地址空间(相对地址空间):源程序经过汇编或编译后,形成目标程序,每个目标程序都是以 0 为基址顺序进行编址的,原来用符号名访问的单元用具体的数据——单元号取代。这样生成的目标程序占据一定的地址空间,称为作业的逻辑地址空间,简称逻辑空间。在逻辑空间中每条指令的地址和指令中要访问的操作数地址统称为逻辑地址

作业的物理地址空间(绝对地址空间):内存是由若干个存储单元组成的,所有存储单元顺序编号,每个存储单元有一个编号,这种编号可唯一标识一个存储单元,称为内存地址(或物理地址)。程序装入内存后,它们占用的主存区域是由绝对地址来确定指令和数据的位置的,通常把这些绝对地址的集合形成的作业空间称为作业的物理地址空间(绝对地址空间)。
在这里插入图片描述

5.2.2.地址映射(重定位)

逻辑地址和物理地址。这两者在多道程序环境下是不一致的,因此存储管理必须提供地址映射功能(重定位),用于把逻辑地址转换为物理地址。

重定位分类定义优点缺点
静态重定位有装配程序来完成。物理地址=起始地址+逻辑地址不需要硬件支持、简单、速度快。无法进行地址变换,无法实现虚拟存储器
1)将程序一旦装入内存后就不能再移动,
2)必须在程序执行前将有关部分全部装入
3) 必须占用连续的内存空间
动态重定位在程序执行过程中,由硬件地址映射机构来完成。基地址寄存器BR,虚地址寄存器 VR,内存地址 MR=BR+VR为实现虚拟存储器提供了基础,有利于存储空间的共享
1) 可以将程序分配到不连续的存储空间
2) 在程序运行之前可以只装入它的部分代码即可投入运行,然后在程序运行期间,根据需要动态申请分配内存
3) 为用户提供一个比主存的存储空间大的多的地址空间。需要硬件
支持,且实现存储管理的软件算法比较复杂。

在这里插入图片描述

5.3 分区存储管理

单道系统: 单一连续存储管理。
多道系统: 最简单的方法是将内存用户区划分成若干区域,每个区域分配给一个用户作业,把用户作业次性全部装入内存,并限定它们只能在自己的区域内运行。

5.3.1 固定分区管理

1.基本思想

系统操作员或 OS将内存空间划分为若干分区,每个分区中驻留一道程序,这些分区的长度可以不同,但分区的个数和每个分区的长度、位置是固定的。

2.分区说明表:PDT
分区号大小内存始址状态
112K20K已分配
232K32K已分配
364K64K已分配
4128K128K未分配
3 分配策略

在调度作业时,存储器管理根据所需量在分区说明表中找出一个足够大的分区分配分区,然后用重定位装入程序。如果找不到合适得分区,则通知作业调度模块,另外选择一个作业。

分配:依次查找分区说明表中的信息,将分区大小满足作业请求容量,并且使用状态为空闲的第一个分区分配给该作业。同时将该分区的状态改为已使用。

回收:作业运行完毕后,将释放的分区收回,设分区使用状态为空闲。

4.优、缺点

优点: 能实现多个作业共享内存,保证多道运行、数据结构简单,分配回收算法容易实现等;

缺点: 内存利用不充分,小作业占用大分区,造成内碎片现象;作业的大小受到分区大小严格限制;

内碎片: 在固定分区方式中,一个分区分配给作业后,分区中未使用的空间区称为内碎片,又称内零头。

5.3.2 可变分区管理

1.基本思想(量体裁衣)

根据作业大小动态地划分分区,使分区大小正好适应作业的需要。克服了内碎片。在这里插入图片描述

2.与固定分区的区别

1) 系统运行过程中,作业装入时建立
2) 个分区的大小不确定
3) 内存中分区的数目可以(一般)不定

3. 主存占有表和空闲说明表(链)

分区说明表:记录占用内存分区的情况;
空闲说明表(空闲分区链):将内存中空闲分区单独构成一个空闲分区表和空闲分区链;

4. 分配策略:主要问题:分配、回收

1) 首次适应算法(FF):按始地址升序排列。从链首开始分配。
分配:从空闲分区表(空闲分区链)首部开始顺序查找,直到找到第一个能满足其大小要求的空闲地址为止。
优点:算法简单,查找速度快,大作业易满足要求。

在这里插入图片描述

2) 最佳适应算法(BF):按分区大小递增的顺序排列。
分配:从空闲分区表(链)首开始查找,直到找到第一个能满足其大小要求的空闲地址为止。
注意:此算法看起来最佳,其实不然。

在这里插入图片描述

3) 最坏适应算法(WF)按分区大小递减的顺序排列。
分配:总是把空闲链中的第一个分区,即将最大的空闲分区分配给作业;
缺点:大作业难以满足要求。
在这里插入图片描述
5. 分区回收
当进程运行完毕释放内存时,系统根据释放区的首址,从空闲链中找到相应的插入点,此时可能出现以下四种情况。
在这里插入图片描述
处理方法:

(a) 不再为回收区分配新表项,而只需修改 F1 的大小。
(b) 用回收区的首址作为新空闲区的首址,大小为两者之和。
© 将三个分区合并,区 F1 的首址,取消 F2 的表项
(d) 新建一个表项。

注:
外碎片:主存中的一个空闲区域在分配给作业后,一般总是剩余一个更小的空闲区。当这样的小分区不能再装入一个作业时,即不能被利用时,它们也成为主存碎片,这样的分区在作用使用的分区之外,所以称为外碎片。

内存紧凑技术( 拼接技术):通过移动各个作业分区的存储位置,把多个外碎片拼接成一个较大的空闲区,从而可以用于存放另一个新的作业。

采用动态重定位技术,一个作业在内存中移动后,只要改变重定位寄存器的内容即可。

5.3.3 分区管理存储保护

存储保护是为了防止一个作业有意或无意地破坏操作系统或其他作业。
1. 界限寄存器保护(上下界保护法)(上、下限)(PCB)
如图示:把作业 X 分配在 60K 到 124K 的一个分区内,当调度到该作业在 CPU 上执行时,由 OS 把这对寄存器分别设置成 60K 和 124K。在作业运行过程中形成的每一个访问地址,与这两个寄存器的值比较,进行地址有效性检验,发现非法访问时产生中断。
在这里插入图片描述
2. 基址,限长寄存器法(基址、限长)
限长寄存器中的值代表可以使用的最大地址位移量(即相对地址或逻辑地址),基址寄存器用以存放运行作业的起始地址。
Load 1,500——取逻辑地址 D=500 号单元的数到 1 号寄存器中。
在 CPU 执行该指令时,由硬件对所要访问的逻辑地址 D 进行检查:
若 D>n(n 为限长值),则说明地址越界,即所要访问的内存地址超出本作业所占用的存储空间,这将产生保护中断,控制转给 OS 去进行出错处理。
若 D<n,则说明地址合法,做重定位工作。

在这里插入图片描述
3. 保护键法(锁、钥匙)(状态子 PSW)
对每个分区分配一个唯一的保护健,它是一个 N 位的二进制代码,相当于该分区的一把锁,而在程序状态寄存器 PSW 种,设置有保护键字段,它相当于一把钥匙,在执行存储访问指令时,先要检查被访问的单元所在分区的锁和钥匙是否相符。若符合则允许访问,否则不可以。因此,当某一分区分配给作业时,同时分配给他一个唯一的键码,当该作业执行时,PSW 中的保护字段置相应的键码。这样,它在访问本作业的存储区时,由于锁钥匙相配可以顺利地进行。如果该作业在运行中不正确的访问时,则会因为钥匙不匹配而产生保护中断,并把控制转给 OS 进行出错处理。为了保证 OS 能够访问内存的所有单元,可以规定一种”万能钥匙”,如当 PSW 中保护键字段全为 0 时,则不进行钥锁匹配检查。这样,就可以访问所有内存空间。

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

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

相关文章

leetCode 226.翻转二叉树

给你一棵二叉树的根节点 root &#xff0c;翻转这棵二叉树&#xff0c;并返回其根节点。 226. 翻转二叉树 - 力扣&#xff08;LeetCode&#xff09; 示例 1: 输入&#xff1a;root [4,2,7,1,3,6,9] 输出&#xff1a;[4,7,2,9,6,3,1] 示例 2&#xff1a; 输入&#xff1a;root…

uniapp 打包的 IOS打开白屏 uniapp打包页面空白

uniapp的路由跟vue一样,有hash模式和history模式, 使用 URL 的 hash 来模拟一个完整的 URL,于是当 URL 改变时,页面不会重新加载。 如果不想要很丑的 hash,我们可以用路由的 history 模式,这种模式充分利用 history.pushState API 来完成 URL 跳转而无须重新加载页面。…

常使用的定时任务

常使用的定时任务 一、 linux自带的定时任务 1、crontab 有这样一个需求&#xff1a;我们使用Java写一个工具jar包在系统空闲的时候去采集已经部署在Linux系统上的项目的一 些数据&#xff0c;可以使用 linux 系统的 crontab。 运行crontab -e&#xff0c;可以编辑定时器&…

OCR文字识别工具 Cisdem OCRWizard激活最新 for Mac

为了提高内容识别的准确性&#xff0c;Cisdem OCRWizard提供供您选择两种模式&#xff1a;文件或名片。此外&#xff0c;它会自动分析的内容&#xff0c;标志着不同颜色的页面上几个区域根据给定部分的性质&#xff1a;文本&#xff08;绿色标记&#xff09;&#xff0c;图像&a…

平凯星辰携手教育部教育管理信息中心,助力普惠教育数字化

近日&#xff0c;企业级开源分布式数据库厂商平凯星辰与教育部教育管理信息中心达成合作&#xff0c;TiDB 分布式数据库为全国中小学管理服务平台提供全栈服务。双方将携手深入探索领先的数据库技术在教育行业的新场景与新应用&#xff0c;既夯实教育数字化底座&#xff0c;助力…

laraval6.0 GatewayWorker 交互通信

laravel 6.0 GatewayWorker 通讯 开发前准备下载 GatewayWorker 及操作方式前端demo测试效果项目中安装GatewayClient开发前准备 GatewayClient 官网:https://www.workerman.net/ 当前使用的是宝塔操作 下载 GatewayWorker 及操作方式 前端demo 测试效果 项目中安装GatewayC…

第二十章Java博客

如果一次只完成一件事情&#xff0c;很容易实现。但现实生活中&#xff0c;很多事情都是同时进行的。Java中为了模拟这种状态&#xff0c;引入了线程机制。简单地说&#xff0c;当程序同时完成多件事情时&#xff0c;就是所谓的多线程。多线程应用相当广泛&#xff0c;使用多线…

乱序学机器学习——主成分分析法PCA

文章目录 概览PCA核心思想和原理PCA求解算法PCA算法代码实现降维任务代码实现PCA在数据降噪中的应用PCA在人脸识别中的应用主成分分析优缺点和适用条件优点缺点适用条件 概览 PCA核心思想和原理 PCA求解算法 特征向量表示分布的方向&#xff0c;特征值表示沿着个方向分布的程度…

牛客 算法题 golang语言实现

题目 HJ101 输入整型数组和排序标识&#xff0c;对其元素按照升序或降序进行排序 描述 输入整型数组和排序标识&#xff0c;对其元素按照升序或降序进行排序数据范围&#xff1a; 1 ≤ &#xfffd; ≤ 10001≤n≤1000 &#xff0c;元素大小满足 0 ≤ &#xfffd; &#…

对称加密与非对称加密的区别是什么?

对称加密与非对称加密的区别是什么&#xff1f; 对称加密概念&#xff1a;好处和坏处&#xff1a;基本原理 非对称加密概念&#xff1a;工作原理&#xff1a; 两者区别安全性处理速度密钥管理通信双方数量 对称加密 概念&#xff1a; 同一个密钥可以同时用来对信息进行加密和…

深入了解Spring Boot中@Async注解的8大坑点

文章目录 1. 缺少EnableAsync注解2. 异步方法需独立3. 不同的异步方法间无法相互调用4. 返回值为void的异步方法无法捕获异常5. 外部无法直接调用带有Async注解的方法6. Async方法不适用于private方法7. 缺失异步线程池配置8. 异步方法与事务的兼容结语 &#x1f389;深入了解S…

OpenMMlab导出FCN模型并用onnxruntime推理

导出onnx文件 直接使用脚本 import torch from mmseg.apis init_modelconfig_file configs/fcn/fcn_r18-d8_4xb2-80k_cityscapes-512x1024.py checkpoint_file fcn_r18-d8_512x1024_80k_cityscapes_20201225_021327-6c50f8b4.pth model init_model(config_file, checkpoin…