410操作系统学习笔记——内存管理(三)

简介: 410操作系统学习笔记——内存管理

2.3.4.时钟置换算法(CLOCK)

1.访问位的实质是反应该内存块最近是否被用过

2.实现方法:访问队列:1、3、4、2、5、6、3、4、7, 内存块为五个

①当访问到6时,无空闲内存块,需要使用CLOCK算法选择淘汰页,此时内存块队列为(1、3、4、2、5),并且它们的访问位都为1(扫描指针此时指向对首1)

f5f03082894d4f27888f5079136a8502.png


②从队首开始向后扫描,每扫描到一个内存块,若访问位1,则改为0;若访问位为0,则将其淘汰:第一轮扫描,将(1、3、4、2、5)的访问位按顺序更改为0(第一轮扫描后,扫描指针转一圈后重新指向1)7d5bfa722c4546478934d6c84a156754.png

③若第一轮扫描没有找到淘汰页面,则采用同样规则进行第二轮扫描:此时扫描到1的访问位为0,即选择1淘汰,并将6装入之前1占有的内存块中,并将6的访问位改为1(第二轮扫描,扫描指针扫描到1就结束扫描,扫描指针指向下一个内存块,即3)c70ba26f2a1d4531aea6657810f036cc.png

④访问3,将3的访问位改为1

⑤访问4,将4的访问位改为1c4983a6f8a0a4b35923fda5fbbc5f9ea.png

⑥访问7,此时再次出现缺页并且无空闲内存块的情况,需要进行缺页处理:扫描指针从3号开始扫描,3号访问位为1,将其改为0,并使扫描指针指向下一个,即4号;扫描4号,4号访问位为1,将其改为0,并使扫描指针指向下一个,即2号;扫描2号,2号扫描位为0,选择2号淘汰,并将7号装入之前2号占有的内存块中,并将7号的访问位改为1,并使扫描指针指向下一个,即5号

26eeb5ca5f30429e8b0302aeb9d467d4.png

2.3.5.改进型的时钟置换算法

第一轮:找没访问、没修改的页面

第二轮:找没访问、有修改的页面

第三轮:找有访问、没修改的页面

第四轮:找有访问、有修改的页面97b84e420eaf42fa86a049d7b4be8f77.png

feeb6f988de54991bb43b14c193a2f13.png

2.4.页面分配策略、抖动、工作集

1.驻留集:请求分页管理方式中给进程分配的物理块的集合

驻留集过小,将会导致频繁的缺页;驻留集过大,多道程序并发度下降(没法同时容纳多个进程的数据),资源利用率降低(不能充分发挥多道程序并发执行的条件下,CPU和I/O设备能够并行工作的特点)

2.固定分配(驻留集大小不变:系统为每个进程分配一组固定数量的物理块,进程执行期间不改变

可变分配(驻留集大小可变):系统先为进程分配一定数量的物理块,在运行期间对这些物理块进行适当的增加或者减少

3.局部置换:发生缺页时只能选进程自己的物理块进行置换

全局置换:缺页进程可以使用系统保留的空闲物理块,也可以使用其他进程的物理块

4.不存在固定分配和全局置换的搭配(固定分配下驻留集大小不能改变,而全局置换将会导致驻留集大小改变)ad5c19f4b8ec4aae86c4fd3451635bf6.png

ab34de586536429da182994c85e89fb4.png

5.调入页面的时机:601771d8c89c4b72895b3368caf1c39c.png

6.从何处调入页面:228e29fc63ea498694914b474fc9fe98.png

7.抖动现象:刚换出外存的页面马上又要换入内存

产生抖动的原因:进程频繁访问的页面数高于可用物理块数(进程物理块不够用)

工作集:某个时间间隔例,进程实际访问页面的集合

根据工作集大小决定驻留集大小464d22dd3df94eeca8ec104e48962a34.png

image.png

2.5.内存映射文件

1.传统的文件访问方式:open→seek→read→write59317a00dc4a432d926dbe36e9d7ee15.png

2.内存映射文件的访问方式:mmap系统调用会给程序员返回一个指向映射区域起始地址的指针

以访问内存的方式访问文件数据:可以通过指针加上地址偏移量访问该指针后面的区域

文件数据的读入、写出由操作系统自动完成:在mmap系统调用的初始状态下,文件数据还没有被读入内存中,只是建立了内存地址空间和外存中文件数据的映射关系,在程序员通过指针访问该地址空间时,实际上是缺页状态;发生这种缺页时,操作系统将会把该地址空间映射的文件数据调入内存,而不需要程序员使用read系统调用

③进程关闭文件时,操作系统自动将文件被修改的数据写回磁盘

72c0142faa1e4c4495e4c821013cd05f.png

3.内存映射文件可以实现文件共享5b5dff1a465b4c8fa8e06dd1dbf439c7.png

8d03d8f59e1a4add9d36d4db2d634419.png





相关文章
|
3天前
|
存储 安全 程序员
深入理解操作系统的虚拟内存管理
【5月更文挑战第31天】 在现代操作系统中,虚拟内存管理是一项至关重要的技术,它使得系统能够有效地管理和利用物理内存资源。通过虚拟内存技术,操作系统为每个运行的程序提供了一个独立的地址空间,从而实现了内存的保护、共享和虚拟扩展。本文将深入探讨虚拟内存的基本原理、实现机制以及它在操作系统中的作用。
|
3天前
|
算法
深入理解操作系统的内存管理机制
【5月更文挑战第31天】 在现代计算机系统中,操作系统扮演着资源管理者的角色,其中内存管理是其核心职能之一。本文将探讨操作系统内存管理的关键技术和原理,包括虚拟内存、分页机制、内存分配策略等,旨在为读者提供一个清晰的框架来理解和评估不同操作系统如何高效、安全地管理有限的物理内存资源。通过对这些概念的深入分析,我们不仅能够更好地理解系统性能和稳定性背后的因素,还能对日常编程实践中遇到的相关问题有更深刻的洞察。
|
3天前
|
存储 缓存 算法
深入理解操作系统的内存管理机制
【5月更文挑战第31天】 在现代计算机系统中,操作系统扮演着核心角色,它负责管理硬件资源并为应用程序提供服务。内存管理是操作系统中一个至关重要的功能,它确保了系统能够高效、安全地分配和回收内存资源。本文将详细探讨操作系统内存管理的关键技术,包括虚拟内存的概念、分页与分段机制、物理与逻辑地址转换,以及内存分配策略等。通过对这些技术的深入分析,读者将获得对操作系统如何优化内存使用和管理过程的深刻理解。
|
3天前
|
缓存 算法 安全
深入理解操作系统内存管理:分页系统的优势与挑战
【5月更文挑战第31天】 在现代操作系统中,内存管理是核心功能之一。分页系统作为内存管理的一种流行技术,其设计哲学基于时间和空间的局部性原理,旨在提高内存利用率和系统性能。本文将探讨分页系统的关键优势及其面临的挑战,包括页面置换算法、内存碎片问题以及虚拟到物理地址转换的复杂性。通过对分页机制的深入分析,我们揭示了它在多任务处理环境中如何允许多个进程共享主存资源,并保证了操作系统的稳定性与高效性。
|
3天前
|
缓存 算法 Java
深入理解操作系统的内存管理机制
【5月更文挑战第30天】 在现代计算机系统中,操作系统扮演着至关重要的角色,它负责协调和管理硬件资源,为应用程序提供必要的服务。其中,内存管理是操作系统的核心功能之一,它不仅关系到系统的稳定性和效率,而且直接影响到应用程序的性能。本文将深入探讨操作系统中的内存管理机制,包括物理内存与虚拟内存的概念、分页系统、内存分配策略以及内存保护等方面。通过对这些技术的细致剖析,旨在帮助读者建立起对操作系统内存管理深层次的认识。
|
3天前
|
程序员 内存技术
深入理解操作系统内存管理:原理与实践
【5月更文挑战第30天】 在现代计算机系统中,操作系统的内存管理是确保系统高效、稳定运行的关键。本文将深入探讨操作系统中内存管理的理论基础和实际应用,包括物理内存与虚拟内存的映射机制、分页与分段技术、以及内存分配策略等。通过对内存管理机制的分析与案例实践,旨在为读者提供一个清晰的内存管理概念框架和操作指南,帮助理解操作系统如何优化内存资源使用,提高系统性能。
|
3天前
|
存储 缓存 算法
深入理解操作系统的内存管理
【5月更文挑战第30天】 本文旨在探讨操作系统中一个至关重要的组成部分——内存管理。我们将从操作系统内存管理的基本原理出发,深入分析不同的内存分配策略以及它们对系统性能的影响。文章还将涉及虚拟内存技术、分页机制以及内存碎片问题,并讨论现代操作系统如何通过各种优化手段提高内存使用效率。通过本文,读者将获得对操作系统内存管理深层次工作原理的理解,并且能够识别和解决与之相关的常见问题。
|
3天前
|
安全 算法 网络协议
探索Linux操作系统的内核管理
【5月更文挑战第31天】本文将深入探讨Linux操作系统的内核管理机制,包括其设计原则、主要组件以及它们如何协同工作以提供高效的系统性能。通过分析Linux内核的关键特性和功能,我们将揭示这一开源操作系统如何在各种计算环境中保持其稳定性和灵活性。
|
12天前
|
存储 缓存 Linux
【Linux】进程概念(冯诺依曼体系结构、操作系统、进程)-- 详解
【Linux】进程概念(冯诺依曼体系结构、操作系统、进程)-- 详解
|
19天前
|
存储 Linux C语言
Linux:冯·诺依曼结构 & OS管理机制
Linux:冯·诺依曼结构 & OS管理机制
18 0