



全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
内存块分配算法和抖动问题2010-03-23 18:531 内存块分配算法1.1 最少内存块数分配给进程的内存块数目是受到限制的,分配的总块数不能超出可用块的总量(除非存在页共享的情况)。另一方面,每个进程也需要有起码最少的块数。很显然,随着分给每个进程块数的减少,缺页率将上升,降低了进程的执行速度。分给每个进程的最少块数是指能保证进程正常运行所需的最少内存数,它是由指令集结构决定的。因为正在执行的指令被完成之前出现缺页时,该指令必须被重新启动,与此相应,必须有足够的块把一条指令所访问的各个页都存放起来。而每个进程的最多块数是由可用内存的总量决定的。1.2 固定分配和可变分配请求分页系统支持虚拟存储器,可以采用两种内存块分配策略,即固定分配和可变分配。(1)固定分配策略是分配给进程的内存块数是固定的,并在最初装入时(即进程创建时)确定块数。分给每个进程的内存块数基于进程类型(交互式、批处理型、应用程序型等),或者由程序员或系统管理员提出 的建议。当进程执行过程中出现缺页时,只能从分给该进程的内存块中进行页面置换。(2)可变分配策略允许分给进程的内存块数随进程的活动而改变。如果一个进程在运行过程中持续缺页率太高,这就表明该进程的局部化行为不好,需要给它分配另外的内存块,以减少它的缺页率。如果一个进程的缺页率特别低,就可以减少分配的内存块,但不要显著增加缺页率。可变分配策略的功能更强,但需要操作系统估价出各活动进程的行为,这就增加了操作系统的软件开销,并且依赖于处理器平台所提供的硬件机制。1.3 全局置换与局部置换内存块分配的另一个重要问题是页面置换范围。多个进程竞争内存块时,可以把页面置换分为两种主要类型:全局置换和局部置换。全局置换允许一个进程从全体存储块的集合中选取置换块,尽管该块当前已分给其他进程,但还是能强行剥夺。而局部置换是每个进程只能从分给它的一组块中选择置换块。采用局部置换策略,分给进程的块数是不能变更的。采用全局置换策略,一个进程可以只从分给其他进程的块里挑选。这样,如果没有别的进程挑选它的块,那么分给该进程的块数就增加了。可以由一个核心进程专门负责页面置换工作。全局置换算法存在的一个问题是,程序无法控制自己的缺页率。一个进程在内存中的一组页面不仅取决于该进程的页面走向,而且也取决于其他进程的页面走向。因此,相同程序由于外界环境不同会造成执行上的很大差别。使用局部置换算法就不会出现这种情况,一个进程在内存中的页面仅受本进程页面走向的影响。1.4 内存块分配算法为每个进程分配内存块的算法主要有三种:等分法、比例法和优先权法。(1)等分法为每个进程分配存储块的最简单的办法是平分,即若有m块、n个进程,则每个进程分m/n块(其值向下取整)。等分法不区分具体进程的需求,“一视同仁”地进行分配。其结果造成:有的进程用不了那么多块,而另外进程却远远不够用。为解决这个问题,可采取按需成比例分配的办法。(2)比例法分给进程的块数=进程地址空间大小 / 全部进程的总地址空间 * 可用块总数上述两种情况下,分给每个进程的块数依据多道程序数目而变。多道程序数增加了,每个进程就要少分一些块。相反,多道程序数少了,分给每个进程的块数可多一些。(3)优先权法在上面两种算法中没有考虑优先级问题,即把高优先级进程和低优先级进程一样对待。为加速高优先级进程的执行,可以给高优先级进程分较多内存。如使用比例分配法时,分给进程的块数不仅取决于程序的相对大小,而且也取决于优先级的高低。2 抖动(Thrashing)问题置换算法的优劣,直接影响到系统的效率。若选用算法不合适,可能会出现这种现象:刚被置换出去的页,很快又要访问,因而要把它重新调入;可是调入不久又再次被置换出去,这样再访问、再调入,如此反复,使得整个系统的页面替换非常频繁,以致大部分的机器时间都花在来回进行的页面调度上,只有一小部分时间用于进程的实际运算。这种局面就称为系统“抖动”。产生抖动的原因是系统中多道程序度过高,进程运行缺页率严般情况下,在多道程序度较小时,随着它的增加,CPU利用率会缓慢增加。当到达最大值后,多道程序度进一步增大,就出现了抖动,导致CPU利用率急剧下降。防止抖动发生或者限制抖动影响的方法有多种,但一般都基于调节多道程序度。(1)采用局部置换策略。如果一个进程出现抖动,它不能从另外的进程那里夺取内存块,从而不会引发其他进程出现抖动,使抖动局限于一个小的范围内。然而这种方法并未消除抖动的发生,而且在一些进程发生抖动的情况下,等待磁盘I/O的进程增多,使得平均缺页处理时间加长,从而延长了有效存取时间。(2)利用工作集策略防止抖动。(3)挂起某些进程。当出现CPU利用率、而磁盘I/O非常频繁的情况时,就可能因为多道程序度太高而造成抖动。为此,可挂起一个或几个进程,以便腾出内存空间供抖动进程使用,从而消除抖动现象。被挂起进程的选择策略有多种,如优先权最低的进程、缺页进程、最近激活的进程、驻留集最小的进程和最大的进程等。(4)采用缺页频度法(PFF,Page Fault Frequency)。抖动发生时缺页率必然很高。这样,通过控制缺页率就可预防抖动。当缺页率太高时,表明进程需要更多的内存块。反之,如果缺页率很低,表示进程可能占用的内存块太多。规定一个缺页率,依此设置相应的上限和下限。如果实际缺页率超出上限值,就为该进程分配另外的内存块;如果实际缺页率低于下限值,就从该进程的驻留集中取走一个内存块。通过直接测量和控制缺页率,就可以预防抖动。3 工作集一个页面置换算法的好坏与进程运行的页面走向有很大的关系。虚拟存储系统的有效操作依赖于程序中访问的局部化程度。对于LRU算法而言,局部化程度愈突出,进程运行效率愈高。局部化可分为两类:时间局部化和空间局部化。时间局部化是指一旦某条指令或数据被访问了,它常常很快又被再次访问,如程序中的循环部分。空间局部化指的是一旦某个位置被访问到,那么它附近的位置也可能很快要用到,如程序中的顺序指令串。这种情况反映在页面走向上,就是在任何一小段时间里,进程运行只集中于访问某几页。工作集就是一个进程在某一小段时间内访问页面的集合。它是程序局部性的近似表示。操作系统监督每个进程的工作集并给它分配足够工作集所需的内存块。
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 家电公司资产评估管理规定
- 慢性创面试题及答案
- 副院长面试题及答案
- 中级会计实务考试试题及答案
- 齿轮加工试题及答案
- 黑林业考试试题及答案
- 基层相关面试题及答案
- 淡水鱼加工试题及答案
- 小学学期末总结
- 2025年执业药师之中药学综合知识与技能题库附答案(基础题)
- 放射科医学影像科专案改善PDCA缩短住院病人等候核磁检查时间品管圈QCC案例
- 小儿巨细胞病毒感染的诊治-2
- 酒店客房样板间装修验收记录表
- 铁总物资〔2015〕250号:中国铁路总公司物资采购异议处理办法
- GB/Z 42625-2023真空技术真空计用于分压力测量的四极质谱仪特性
- 人民医院心血管外科临床技术操作规范2023版
- 助理工程师考试试题以及答案
- 送东阳马生序
- 2017年全国大学生数学建模A题
- 2023年专升本计算机题库含答案专升本计算机真题
- GB/T 16674.1-2016六角法兰面螺栓小系列
评论
0/150
提交评论