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





相关文章
|
1天前
|
算法 安全 UED
探索操作系统的内核空间:虚拟内存管理
【7月更文挑战第50天】 在现代操作系统中,虚拟内存管理是核心功能之一,它允许操作系统高效地使用物理内存,并为应用程序提供独立的地址空间。本文将深入探讨操作系统虚拟内存管理的机制,包括分页、分段以及内存交换等关键技术,并分析它们如何共同作用以实现内存的有效管理和保护。通过理解这些原理,读者可以更好地把握操作系统的内部工作原理及其对应用程序性能的影响。
|
14天前
|
存储 算法 安全
深入剖析操作系统的内存管理机制
在数字世界的构建中,操作系统扮演着至关重要的角色。本文将探讨操作系统中的内存管理机制,揭示其背后的技术原理和设计哲学。从内存分配策略到虚拟内存的实现,再到内存保护和回收机制,我们将一探究竟,解析操作系统如何高效、安全地管理宝贵的内存资源。
|
15天前
|
算法 程序员
理解操作系统内存管理:页面置换算法全解析
大家好,我是小米,热爱分享技术的大哥哥!今天聊的是操作系统中的页面置换算法。它解决的是内存满载时,如何选择合适的页面移出以腾出空间的问题。主要有三种算法:FIFO(先进先出),简单但性能不佳;LRU(最近最久未使用),考虑时间局部性,性能较好但实现较复杂;OPT(最佳置换),理论上最优但无法实际应用。这些算法各有千秋,在实际应用中需根据场景选择最合适的方案。希望这能帮大家更好地理解内存管理的核心机制!
32 2
|
19天前
|
分布式计算 算法 内存技术
深入理解操作系统的内存管理机制
【7月更文挑战第32天】 在现代计算机系统中,操作系统扮演着至关重要的角色,它负责协调和管理整个系统的资源。其中,内存管理作为操作系统的核心功能之一,其效率和稳定性直接影响到系统的整体性能。本文旨在探讨操作系统中内存管理的基本原理、关键技术以及面临的挑战,为读者提供一个全面了解内存管理机制的视角。通过分析不同的内存分配策略、分页与分段机制以及虚拟内存技术,我们揭示了操作系统如何优化内存使用,保证多任务环境下的数据完整性和安全性。
|
21天前
|
Cloud Native Devops 数据库
云原生架构:未来软件开发的引擎深入理解操作系统的虚拟内存管理
【7月更文挑战第30天】在这篇文章中,我们将深入探讨云原生架构的概念,以及它如何改变软件开发的世界。我们将从云原生的基本概念开始,然后深入到它的关键技术和实践,最后讨论它对软件开发的未来影响。无论你是软件开发者,还是IT专业人士,这篇文章都将为你提供深入理解和掌握云原生架构的重要信息。 【7月更文挑战第30天】在数字世界的构建中,虚拟内存是操作系统不可或缺的一环。本文将探索虚拟内存的核心概念、工作机制及其对现代计算环境的重要性,同时揭示其背后的技术细节和面临的挑战。
17 3
|
20天前
|
监控 算法 Java
探索现代操作系统的内存管理机制
【7月更文挑战第31天】本文深入探讨了操作系统中至关重要的内存管理功能,包括虚拟内存、分页、分段以及内存分配策略等。文章旨在解释这些复杂概念背后的原理,并展示它们如何共同作用于提升系统性能和资源利用效率。我们将从内存管理的基础知识出发,逐步过渡到高级话题,如内存泄漏检测与垃圾回收机制,为读者提供全面而深入的理解。
35 0
|
21天前
|
存储 缓存 数据处理
操作系统中的内存管理优化策略
【7月更文挑战第30天】在计算机科学领域,内存管理是操作系统设计中的核心问题之一。有效的内存管理不仅能够提升系统性能,还能确保程序的高效运行。本文将探讨几种先进的内存管理技术,包括分页机制、虚拟内存、缓存策略以及最新的内存压缩技术。通过深入分析这些技术的实现原理与应用效果,本文旨在为读者提供一套系统的内存管理优化策略,帮助开发者和系统管理员更好地理解和应对内存资源的挑战。
21 0
|
21天前
|
缓存 监控 安全
探索Linux操作系统的内存管理机制
在计算机科学的世界中,内存管理是操作系统核心功能之一,它直接影响系统的性能和稳定性。Linux操作系统以其高效的内存管理而闻名,其设计哲学和技术实现为开发者和系统管理员提供了极大的灵活性和控制力。本文将深入探讨Linux内存管理的基本原理、关键技术以及面临的挑战,同时通过实际案例分析,展示如何优化内存使用,提升系统性能。
|
22天前
|
存储 Linux Windows
操作系统中的内存管理:从原理到实践
内存管理是操作系统中的核心功能,它直接影响着系统的性能和稳定性。本文将深入探讨内存管理的基本原理、关键技术以及实际应用,帮助读者更好地理解内存管理在操作系统中的重要性。
|
1月前
|
安全 Linux 网络安全
部署07--远程连接Linux系统,利用FinalShell可以远程连接到我们的操作系统上
部署07--远程连接Linux系统,利用FinalShell可以远程连接到我们的操作系统上