内存空间的扩充

一、覆盖技术

解决程序大小超过物理内存总和问题

1.思想

将程序分为多个段/模块,常用段常驻内存,不常用段在需要时调入内存

2.组成

固定区(存放常驻内存,调入后到运行结束时才调出)+覆盖区(存放不常用段,需要时调入,不需要时调出内存)

二、交换技术

1.思想

内存空间紧张时,系统将内存中某些进程暂时换出外存(挂起状态),将外存中某些已具备运行条件的进程换入内存。实质是进程在内存与磁盘间的动态调度,即内存调度,决定将哪个处于挂起状态的进程重新调入内存。

2.磁盘空间组成

文件区(采用离散分配方式存放文件)+对换区(存放被换出的进程数据,采用连续分配方式)

对换区的I/O速度比文件区更快

3.交换原则

优先换出阻塞进程、长驻优先级低的进程;PCB会常驻内存,不会被换出外存

区别:覆盖是在同一个程序或进程中进行的;交换是在不同进程之间进行的。

三、虚拟存储技术

1.传统存储管理方式

必须要一次性将作业全部装入内存才运行,作业装入内存后会一直驻留在内存中,内存空间不够。

2.实现原理

由局部性原理设计(时间局部性-大量循环导致的多次访问某数据

空间局部性-数据连续存放导致的多次访问存储单元及其附近的区域)

在程序装入时,将很快会用到的程序装入内存,暂时用不到的部分留在外存 ------>程序执行时,访问信息不在内存时,由操作系统将信息从外存调入内存------>若内存空间不够,OS将内存中暂时用不到的信息换出到外存

3.虚拟内存

在操作系统管理下,用户使用似乎有一个比实际内存大得多的内存。

特征:多次性-允许作业被分成多次调入内存;对换性-允许作业在运行过程中换入、换出;虚拟性-从逻辑上扩充内存容量

4.实现过程

采用离散分配的内存管理方式 ,由于虚拟内存的特点,需要在非连续(离散)分配存储管理的基础上增加请求调页/调段功能、页面/段置换功能。

相关推荐
fakerth5 小时前
【OpenHarmony】communication_ipc模块
操作系统·openharmony
Coisinier8 小时前
RHCE中shell脚本基础(磁盘剩余空间监控,Web 服务状态检查,curl 访问 Web 服务并返回状态)
linux·运维·服务器·前端·nginx·操作系统
小宇子2B2 天前
free 完再 malloc 同样大小,为什么常拿回刚还回去的那块?
操作系统
触底反弹3 天前
拷个 .exe 到新电脑就跑不起来?你缺的不是文件,是对链接的理解
c++·windows·操作系统
杊页4 天前
第一板块:Android 系统基石与运行原理 | 第二篇:Android 编译、打包与安装机制
android·操作系统
壮Sir不壮4 天前
GO语言——GMP调度模型
linux·开发语言·golang·go·操作系统·线程·协程
Surest4 天前
OpenHarmony 技术拆解(二):从 capability 看懂分布式软总线与任务迁移
操作系统
OpenAnolis小助手4 天前
如何利用 AI Agent 实现热补丁的自动化生成
人工智能·安全·ai·操作系统·agent·龙蜥
小宇子2B6 天前
缺页中断不是“出错”,是内核最忙的一条正常路径
操作系统
小宇子2B6 天前
内存不够时,内核怎么把"冷"页踢出去——swap 与页面回收
操作系统