七、OS连续内存分配

简介: 七、OS连续内存分配

1、内存碎片问题


空闲内存不能被使用,这些内存就称为内存碎片。内存碎片又可以分为外部碎片和内部碎片两种。其中,当给多个应用程序分配内存空间之后,在不同应用程序之间残留小块的内存空间,无法被利用,这些残留的内存空间就叫外部内存碎片。在已经分配给应用程序的空间中,无法被应用程序使用的内存空间称为内部内存碎片。




2、分区的动态分配


当一个程序被准许在内存中运行时,OS会为其分配一个连续的区间;当应用程序需要访问某些数据时,OS会分配一个连续的内存区间以供应用程序来访问数据。下面介绍3个简单的内存分配算法:首次适配;最优适配和最差适配


2.1 首次适配算法-first fit


从低位地址开始寻找空闲的地址空间,若寻找到满足要求的空闲地址空间,则将需求直接分配给首次遇到的空闲地址空间。如下图所示,采用first fit分配算法时,将使用1K bytes的空间作为目标空间进行分配。


3c28a720f7e14666907dd5e5d35599b5.png


在进行重分配的时候还需要进行内存回收的检查,检查是否自由分区能和相邻的空闲分区进行合并。


first fit方法操作简单,易于产生更大的空闲块,但容易产生外部碎片,同时空间分配具有不确定性。




2.2 最优适配算法-best fit


从低位地址开始寻找空闲的地址空间,若寻找到满足要求的空闲地址空间,则记录空闲地址空间和所需空间大小之间的差值,最终选择差值最小的空闲空间作为目标地址空间分配给需求空间。如上图所示,采用best fit分配算法时,将选取500 bytes的地址空间进行分配。


best fit避免了分割大空闲块,同时最小化了外部碎片产生的尺寸,对于小尺寸的内存分配时非常有效,操作简单。但best fit使得外部碎片比较小,更难以利用。


2.3 最差适配算法-worst fit


从低位地址开始寻找空闲的地址空间,若寻找到满足要求的空闲地址空间,则记录空闲地址空间和所需空间大小之间的差值,最终选择差值最大的空闲空间作为目标地址空间分配给需求空间。如上图所示,采用worst fit分配算法时,将选取2K bytes的地址空间进行分配。


worst fit避免了太多微小的碎片,对于分配中尺寸效果最好,但其易于破碎大的空闲块使得大分区无法被分配。




3、压缩式碎片处理-compaction



将已经在内存中的程序进行位置的挪动,从而使得某些细小的外部内存碎片进行合并成为连续的内存空间。但这种方法需要将程序的地址空间进行拷贝和复制,会造成较大的开销。

de6a6326f91844acaf5ed8ccf3ca83f4.png



4、交换式碎片处理-swapping


利用硬盘作为内存的备份,将硬盘利用起来。将某些暂时不执行的程序放到硬盘进行暂时的储存,给需要的程序腾出更多的内存空间。



281fff09d8d44c1385b2f5a081fbeb86.png

swapping后续还需要考虑到选择哪个程序进行转移?在何时进行换入和换出的操作?在虚存管理中会优化换入和换出操作。






相关文章
|
4月前
|
存储 Linux 调度
深入理解操作系统:从进程管理到内存分配
【8月更文挑战第44天】本文将带你深入操作系统的核心,探索其背后的原理和机制。我们将从进程管理开始,理解如何创建、调度和管理进程。然后,我们将探讨内存分配,了解操作系统如何管理计算机的内存资源。最后,我们将通过一些代码示例,展示这些概念是如何在实际操作系统中实现的。无论你是初学者还是有经验的开发者,这篇文章都将为你提供新的视角和深入的理解。
|
5月前
|
安全 索引
操作系统中的内存管理策略
【8月更文挑战第23天】
125 1
|
1月前
|
C语言 开发者 内存技术
探索操作系统核心:从进程管理到内存分配
本文将深入探讨操作系统的两大核心功能——进程管理和内存分配。通过直观的代码示例,我们将了解如何在操作系统中实现这些基本功能,以及它们如何影响系统性能和稳定性。文章旨在为读者提供一个清晰的操作系统内部工作机制视角,同时强调理解和掌握这些概念对于任何软件开发人员的重要性。
|
1月前
|
Linux 调度 C语言
深入理解操作系统:从进程管理到内存优化
本文旨在为读者提供一次深入浅出的操作系统之旅,从进程管理的基本概念出发,逐步探索到内存管理的高级技巧。我们将通过实际代码示例,揭示操作系统如何高效地调度和优化资源,确保系统稳定运行。无论你是初学者还是有一定基础的开发者,这篇文章都将为你打开一扇了解操作系统深层工作原理的大门。
|
2月前
|
算法 调度 开发者
深入理解操作系统:从进程管理到内存分配
本文旨在为读者提供一个深入浅出的操作系统知识之旅,从进程管理的基础概念出发,探索内存分配的策略与技巧。我们将通过实际代码示例,揭示操作系统背后的逻辑与奥秘,帮助读者构建起对操作系统工作原理的直观理解。文章不仅涵盖理论知识,还提供实践操作的指导,使读者能够将抽象的概念转化为具体的技能。无论你是初学者还是有一定基础的开发者,都能在这篇文章中找到有价值的信息和启发。
|
2月前
|
算法 调度 C++
深入理解操作系统:从进程管理到内存分配
【10月更文挑战第42天】本文将带你进入操作系统的神秘世界,探索其核心概念和关键技术。我们将从进程管理开始,了解操作系统如何协调和管理多个程序的运行;然后,我们将深入研究内存分配,看看操作系统如何有效地分配和管理计算机的内存资源。通过这篇文章,你将获得对操作系统工作原理的深入理解,并学会如何编写高效的代码来利用这些原理。
|
3月前
|
分布式计算 算法 大数据
探索操作系统的核心:调度与内存管理机制
【10月更文挑战第11天】 本文深入探讨了操作系统中两大核心功能——调度与内存管理机制。通过分析调度算法、进程状态转换及内存分配策略等关键方面,揭示了它们如何共同维护系统性能和稳定性。旨在为读者提供对操作系统内部运作的深刻理解,同时引起对优化策略的思考。
87 5
|
3月前
|
算法
深入理解操作系统:内存管理机制的探索之旅
【10月更文挑战第2天】在数字世界的浩瀚海洋中,操作系统犹如一艘精密的航船,承载着软件与硬件的和谐共舞。本文将揭开内存管理的神秘面纱,从基础概念到高级策略,引领读者领略操作系统内存分配的智慧。通过深入浅出的解释和生动的比喻,我们一同遨游在内存的江河之中,感受操作系统如何巧妙地协调资源,确保数据的有序流动。让我们跟随内存的脚步,探索那些隐藏在每次点击、每次命令背后的奥秘。
|
3月前
|
监控 开发者
深入理解操作系统:内存管理的艺术
【10月更文挑战第2天】在数字世界的幕后,操作系统扮演着至关重要的角色。本文将深入探索操作系统的心脏——内存管理,揭示它是如何协调和管理计算机的宝贵资源。通过浅显易懂的语言和生活化的比喻,我们将一起走进内存管理的奥秘世界,了解它的原理、机制以及为何对整个系统的性能和稳定性有着不可替代的影响。无论你是技术新手还是资深开发者,这篇文章都将为你打开新的视角,让你对日常使用的设备有更深层次的认识和尊重。
|
3月前
|
缓存 算法 调度
深入浅出操作系统:从进程管理到内存优化
本文旨在为读者提供一次深入浅出的操作系统之旅。我们将从进程管理的基本概念出发,逐步深入到内存管理的复杂世界,最终探索如何通过实践技巧来优化系统性能。文章将结合理论与实践,通过代码示例,帮助读者更好地理解操作系统的核心机制及其在日常技术工作中的重要性。无论你是初学者还是有一定经验的开发者,这篇文章都将为你打开一扇通往操作系统深层次理解的大门。