【操作系统】第三章:计算机体系结构及内存分层体系(Part2:连续物理内存分配)

简介: 【操作系统】第三章:计算机体系结构及内存分层体系(Part2:连续物理内存分配)

目录


  • 内存碎片问题
  • First-fit最先适配
  • Best-fit最佳适配
  • Worst-fit最差适配
  • 压缩式碎片整理
  • 交换式碎片整理


正文


内存碎片问题


当我们给一个运行的程序分配一块空间的时候,会出现一些无法进一步利用的空闲空间。这就是碎片,碎片分为两种(外碎片、内碎片)

外碎片:分配单元之间的没法去使用的内存

内碎片:已经分配给应用程序,但是应用程序无法进一步去使用的空闲内存

两者都是我们尽量想去避免的。

99999999999999999999999999.gif

解决碎片问题:一种有效的内存分配方法!

从OS的角度,它在什么时候会提供连续空间的分配呢?因为OS要把APP从硬盘加载到内存中去,实际上就要给内存中分配一块连续区域让程序可以跑起来;另一种情况应用程序在运行时,会访问数据,这时候OS需要给数据分配空间。为此OS需要管理空闲的和非空闲的空间,这里会通过一些数据结构或者算法来进行识别哪些空闲哪些非空闲并管理。

内存分配算法:

9aa8f60852e4fb20aa2c773487c4c0c2_watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L0NoYWhvdA==,size_16,color_FFFFFF,t_70.png


First-fit最先适配


就活该报应.gif

黄色表示空闲空间,绿色表示非空闲空间。看上去简单易懂,但是它的实现也需要一定条件。

需求:

1.按照地址牌序空闲块

2.分配需要寻找一个合适的分区

3.重分配需要检测

分配过程也需要考虑内存回收问题,回收时要考虑是否可以把空闲块合并,因为一旦合并可以形成更大的空间块,就可以满足更多的应用需求

优点:简单。在高地址有大块空间。

缺点:容易形成外碎片,具有不确定性。


Best-fit最佳适配


是汉朝唐朝.gif

按照最适合,最贴近分配请求的size分配空闲块。

1.按照地址牌序空闲块

2.分配需要寻找一个合适的分区

3.重分配需要检测

优点:比较简单。当大部分分配是小尺寸是非常有效

缺点:外部碎片问题仍然严重。重分配慢。易产生很多无用的小碎片,影响后续管理


Worst-fit最差适配


是出于森给.gif

按照size差距最大的去分配,这种适配可以把大块变小块,小块尽量保留。原理是外碎片大,大概率该碎片可以继续使用。

1.按照地址牌序空闲块

2.分配需要寻找一个合适的分区

3.重分配需要检测

优点:总体来说分配速度比较快;加入分配请求是中大型的,效果较好

缺点:重分配慢;外部碎片;拆分大空闲块导致以后大块区无法被分配


综上:三种分配方法没有最好,只有根据情况进行适用。

所以我们需要一定的碎片处理方式


压缩式碎片整理


花费8off大哥.gif

这里的问题:

1.进程合并挪动过程的实质其实是拷贝内存(开销比较大)的过程,但是,程序执行过程中是不能去挪动的,那么就要等到程序空闲时间处理该才做。

2.挪动到理想位置的开销有多大。这些是需要考虑的问题。


交换式碎片整理


的话是一个.gif

目的:充分利用硬盘,把硬盘当成内存的后备。

现在有四个程序,其中P3正在执行,也就说P1P2P4在内存中等待被执行,如果这时候P3在执行过程中突然需要更多内存,但是P124已经把内存空间占满,需要抢占。P4在等待某个事件产生且等待时间相对较长,为此我们把P4所占用的空间挪到硬盘上去,这样内存中就释放出了空间。这时候P3利用腾出的空闲块继续正常执行。

这里的问题:1.什么时候进行换入和换出操作 2.选哪一个程序换出空间

另一方面换入换出的粒度是以单个程序的大小作为粒度的,也就说如果程序本身比较大,那么换入换出的开销也很大。

那么如何管理和优化呢?这将在后续的【虚存管理】中进行详细讲解,这里只了解这两种分配方式。

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