操作系统体系结构和内存分层

简介: 操作系统体系结构和内存分层

操作系统体系结构和内存分层


计算机体系结构、内存分层体系


计算机基础硬件:

  • CPU:
  • 内存:
  • 设备IO:


内存的层次结构(从上到下速度一次递减):

  • 寄存器
  • cache
  • 主存(物理内存):
  • 磁盘(虚拟内存):


操作系统内核-内存管理的目标:

  • 抽象:逻辑地址空间
  • 保护:独立地址空间
  • 共享:访问相同内存
  • 虚拟化:更多的地址空间


操作系统中管理内存的不同方法:

  • 程序重定位
  • 分段
  • 分页
  • 虚拟内存
  • 按需分页虚拟内存


实现高度依赖于硬件

  • 必须知道内存架构
  • MMU(内存管理单元):硬件组负责处理CPU的内存访问请求


地址空间&地址生成


  • 物理地址空间:硬件支持的值空间
  • 逻辑地址空间:一个运行程序所拥有的内存范围


逻辑地址和物理地址转换


CPU方面:

  • 运算器需要在逻辑地址的内存内容
  • 内存管理单元寻找在逻辑地址和物理地址之间的映射
  • 控制器从总线中发送在物理地址的内存请求


内存方面:

  • 内存发送物理地址内存中的内容给CPU


操作系统方面:

  • 建立逻辑地址和物理地址之间的映射


连续内存分配


  • 内存碎片问题
  • 空闲内存不能被利用
  • 外部碎片:在分配单元间的未使用内存
  • 内部碎片:在分配单元中的未使用内存


  • 分区的动态分配


简单的内存管理方法


当一个程序准许运行在内存中时,分配一个连续的区间

分配一个连续的内存区间给运行的程序以访问数据


分配策略:


第一适配:


为了分配n字节,使用第一个可用空闲块以致块的尺寸比n大;

需求:按照地址排序的空闲块列表,分配需要寻找一个合适的分区,重分配需要检查看是否自由分区能合并于相邻的空闲分区。

优点:易于产生更大的空闲块,向着地址空间的结尾。

缺点:容易产生外部碎片,不确定性。


最佳适配:


为了避免分割大的空闲块,为了最小化外部碎片产生的尺寸

需求:按照尺寸排列的空闲块列表,分配需要寻找一个合适的分区,重分配需要搜索以及合并于相邻的空闲分区。

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

缺点:外部碎片,重分配慢,易产生很多没用的微小碎片


最差适配:


为了避免有太多微小碎片

需求:按尺寸配列的空闲块列表,分配很快,重新分配需要合并于相邻的空闲分区,然后调整空闲块列表

优点:假如分配是中等尺寸效果最好

缺点:重分配慢,外部碎片,易于破碎大的空闲块以致大分区无法被分配


  • 压缩式碎片整理
  • 通过拷贝方式将碎片内存块整理成连续的内存块
  • 交换式碎片整理
  • 运行程序需要更多的内存
  • 抢占等待的程序&回收他们的内存
目录
相关文章
|
2月前
|
存储 Linux 调度
深入理解操作系统:从进程管理到内存分配
【8月更文挑战第44天】本文将带你深入操作系统的核心,探索其背后的原理和机制。我们将从进程管理开始,理解如何创建、调度和管理进程。然后,我们将探讨内存分配,了解操作系统如何管理计算机的内存资源。最后,我们将通过一些代码示例,展示这些概念是如何在实际操作系统中实现的。无论你是初学者还是有经验的开发者,这篇文章都将为你提供新的视角和深入的理解。
|
3月前
|
安全 索引
操作系统中的内存管理策略
【8月更文挑战第23天】
84 1
|
1月前
|
分布式计算 算法 大数据
探索操作系统的核心:调度与内存管理机制
【10月更文挑战第11天】 本文深入探讨了操作系统中两大核心功能——调度与内存管理机制。通过分析调度算法、进程状态转换及内存分配策略等关键方面,揭示了它们如何共同维护系统性能和稳定性。旨在为读者提供对操作系统内部运作的深刻理解,同时引起对优化策略的思考。
59 5
|
1月前
|
算法
深入理解操作系统:内存管理机制的探索之旅
【10月更文挑战第2天】在数字世界的浩瀚海洋中,操作系统犹如一艘精密的航船,承载着软件与硬件的和谐共舞。本文将揭开内存管理的神秘面纱,从基础概念到高级策略,引领读者领略操作系统内存分配的智慧。通过深入浅出的解释和生动的比喻,我们一同遨游在内存的江河之中,感受操作系统如何巧妙地协调资源,确保数据的有序流动。让我们跟随内存的脚步,探索那些隐藏在每次点击、每次命令背后的奥秘。
|
1月前
|
监控 开发者
深入理解操作系统:内存管理的艺术
【10月更文挑战第2天】在数字世界的幕后,操作系统扮演着至关重要的角色。本文将深入探索操作系统的心脏——内存管理,揭示它是如何协调和管理计算机的宝贵资源。通过浅显易懂的语言和生活化的比喻,我们将一起走进内存管理的奥秘世界,了解它的原理、机制以及为何对整个系统的性能和稳定性有着不可替代的影响。无论你是技术新手还是资深开发者,这篇文章都将为你打开新的视角,让你对日常使用的设备有更深层次的认识和尊重。
|
1月前
|
缓存 算法 调度
深入浅出操作系统:从进程管理到内存优化
本文旨在为读者提供一次深入浅出的操作系统之旅。我们将从进程管理的基本概念出发,逐步深入到内存管理的复杂世界,最终探索如何通过实践技巧来优化系统性能。文章将结合理论与实践,通过代码示例,帮助读者更好地理解操作系统的核心机制及其在日常技术工作中的重要性。无论你是初学者还是有一定经验的开发者,这篇文章都将为你打开一扇通往操作系统深层次理解的大门。
|
1月前
|
存储 算法 C语言
MacOS环境-手写操作系统-17-内存管理算法实现
MacOS环境-手写操作系统-17-内存管理算法实现
36 0
|
1月前
|
Java C语言 iOS开发
MacOS环境-手写操作系统-16-内存管理 解析内存状态
MacOS环境-手写操作系统-16-内存管理 解析内存状态
35 0
|
1月前
|
存储 算法 C语言
MacOS环境-手写操作系统-15-内核管理 检测可用内存
MacOS环境-手写操作系统-15-内核管理 检测可用内存
35 0
|
2月前
|
Python
python对电脑的操作,获取几核,获取操作系统,获取内存
python对电脑的操作,获取几核,获取操作系统,获取内存