操作系统第9章ppt课件.ppt
《操作系统第9章ppt课件.ppt》由会员分享,可在线阅读,更多相关《操作系统第9章ppt课件.ppt(74页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、操作系统概念第九章:虚拟内存本章主要内容n背景n按需调页n写时复制n页面置换n帧分配n系统颠簸n内存映射文件n其他考虑29.1 背景n常规存储方器管理方式的特征:n一次性n驻留性3程序执行的局部性原理程序执行的局部性原理虚拟存储的虚拟存储的理论依据理论依据n程序执行时,除了少部分的转移和过程调用外,在大多数情况下仍是顺序执行的n过程调用将会使程序的执行轨迹由一部分区域转至另一部分区域,但研究发现,过程调用的深度在大多数情况下都不超过5。即程序将会在一段时间内局限在这些过程的范围内运行。n程序中存在很多循环结构,这些虽然只是少数指令构成,但是他们将多次执行。n程序中还包括许多对数据结构的处理,比
2、如数组,他们往往都局限于很小的范围内4局限性又表现在下述两个方面n时间局限性n如果程序中某条指令一旦执行,则不久后该指令可能再次执行;如果某数据被访问过,则不久后该数据可能再次被访问n产生时间局限性的典型原因是由于在程序中存在着大量的循环操作n空间局限性n一个程序访问了某个存储单元,在不久之后,其附近的存储单元也将被访问。即程序在一段时间内所访问的地址,可能集中在一定的范围之内n典型原因就是程序的顺序执行5n在许多情况下,(加载)整个程序是没必要的在许多情况下,(加载)整个程序是没必要的n允许程序部分加载即可运行会有许多好处:允许程序部分加载即可运行会有许多好处:nA program woul
3、d no longer be constrained by the amount of physical memory.nMore programs could be run at the same time,with a corresponding increase in CPU utilization and throughput.nLess I/O would be needed to load or swap each user program into memory,so each user program would run faster.6n 虚拟存储虚拟存储用户逻辑存储与物理存
4、储分离用户逻辑存储与物理存储分离n仅部分程序必须在内存,以使其运行仅部分程序必须在内存,以使其运行n 从而逻辑地址空间远大于物理地址空间从而逻辑地址空间远大于物理地址空间 使得编程更加容易,程序员只需关心所要解决的问题使得编程更加容易,程序员只需关心所要解决的问题 采用虚拟内存的系统几乎用不到覆盖采用虚拟内存的系统几乎用不到覆盖n 允许更有效的进程创建允许更有效的进程创建(写时拷贝写时拷贝)n所谓虚拟存储器,是指具有请求调入功能和置换功能,能从逻辑上对内存容量加以扩充的一种存储器系统7虚拟内存大于物理内存的示意图虚拟内存大于物理内存的示意图虚拟内存大于物理内存的示意图虚拟内存大于物理内存的示意
5、图8n虚拟存储可通过以下方式实现虚拟存储可通过以下方式实现:n nDemand paging 请求分页管理方式n nDemand segmentation 请求分段管理方式式n但是,段的替换算法比页替换算法复杂,因为段的大小不同n npaged segmentation 请求段页式管理方式9n其逻辑容量是由内存容量和外存容量之和所决定的,其运行速度接近于内存速度,而每位的成本却又接近于外存。可见,虚拟存储器是一个性能非常优越的存储管理技术,故被广泛应用于大、中、小型机器和微型机中n虚拟存储器的实现都毫无例外地建立在离散分配的存储管理方式的基础上n虚拟存储器的特征:多次性、对换性、虚拟性109.
6、2 按需调页n一个执行程序如何从磁盘载入内存?n将整个程序载入内存n在需要时调入相应的页按需调页11n按需调页系统类似于按需调页系统类似于分页系统对换分页系统对换nBut we use a lazy swapper-pagernSwapper(交换程序交换程序)vs Pager(调页程序调页程序)n nA pager never swaps a page into memory unless that page will be needed.n nA swapper manipulates entire processes.12分页的内存与邻接的磁盘空间之间的传递139.2.1 基本概念n只在
7、页面需要时,才把它们载入内存n需要更少的输入输出n更小的内存n更快的响应n更多的用户14有效-无效位n页表中的每一条目与一有效无效位与之关联。(1表示该页在内存中,0表示不在内存)n有效无效位初始为0n当进程试图访问那些尚未调入到内存的页时,对标记为无效的页面的访问会产生页错误陷阱(page-fault trap)15当有些页不在内存中时的页表16页错误的处理1.检查进程的页表,以确定该引用是合法还是非法的地址访问。2.如果引用非法,那么终止进程。如果引用有效但是尚未调入页面,那么现在应调入。3.找到一个空闲帧(从空闲帧链表中取一个)4.调度一个磁盘操作,以便将所需要的页调入刚分配的帧5.当磁
8、盘读操作完成后,修改进程的内部表和页表,以表示该页已在内存中。6.重新开始因非法地址陷阱而中断的指令。进程现在能访问所需的页,就好像它似乎总在内存中。17处理页错误的步骤18n纯粹按需调页纯粹按需调页nNever bring a page into memory until it is required.nStart executing a process with no pages in memoryn理论上,某些程序每次执行指令可能访问多个理论上,某些程序每次执行指令可能访问多个新新内存页内存页none page for the instruction and many for datan
9、possibly causing multiple page faults per instruction.nFortunately,programs tend to have locality of locality of referencereference(引用的局部性)(引用的局部性)(引用的局部性)(引用的局部性)19请求页式调度的性能n设P为页错误的概率(0P 1)n如果P等于0,则不存在页错误n如果等于,则每次访问都存在页错误n有效访问时间n(1P)内存访问时间+P页错误时间n设内存访问时间为100ns,平均错误页处理为25ms,则EAT为nEAT=(1-P)100ns+P 25
10、msn =100+24999900P ns20Page-fault service timenA page fault caused the following sequence to occur:nTrap to the OSnSave the user registers and process statenDetermine that the interrupt was a page faultnCheck that the page reference was legal and determine the location of the page on the disknIssue
11、a read from the disk to free framenWhile waiting,allocate the CPU to some other usernReceive an interrupt from the disk I/O(I/O completed)nSave the registers and process state for the other usernDetermine that the interrupt was from the disknCorrect the page table and other tables to show that the d
12、esired page is now in memorynWait for the CPU to be allocated to this process againnRestore the user registers,process state,and new page table,and then resume the interrupted instruction21三个主要的页错误处理时间n处理页错误中断n读入页n重新启动进程22nExamplenMemory access time=100 nanosecondsnAn average page-fault service time
13、=25 millisecondsnEAT(in nanoseconds)=(1 p)x ma +p x Page-fault service time =(1 p)x 100 +p x 25,000,000 =100+24,999,900 x p nThe EAT is directly proportional to the page-fault rate.nIf we want less than 10-percent degradation,we need 110 100+25,000,000 110 100+25,000,000 x p 10 25,000,000 10 25,000,
14、000 x p p 0.0000004n请求页面调度中,降低页错误率是非常重要的请求页面调度中,降低页错误率是非常重要的n请求页面调度的另一个重要方面是交换空间的处理和使用请求页面调度的另一个重要方面是交换空间的处理和使用239.3 写时复制(Copy on write)n写时拷贝允许父进程和子进程开始时共享同一页面。n这些页面标记为写时复制,即如果任何一个进程需要对页进行写操作,那么就创建一个共享页的拷贝。n采用写时拷贝技术,很显然只有被进程所修改的页才会复制,因此创建进程更有效率。n写时拷贝时所需的空闲页来自一个空闲缓冲池。该缓冲池中的页在分配之前先填零,以清除以前的页内容。24p pag
15、e Aage Apage Bpage Bpage Cpage Cprocessprocess1 1processprocess2 2physical memoryF Fig.Before processig.Before process1 1 modifies page C.modifies page C.p page Aage Apage Bpage Bpage Cpage Cprocessprocess1 1processprocess2 2physical memoryF Fig.After processig.After process1 1 modifies page C.modif
16、ies page C.C Copy of page Copy of page C259.4 页面置换n给原有的页错误服务程序增加页置换,可以防止内存的过度分配过度分配(over-allocating)。26需要页置换的情况279.4.1 页置换的基本方法1.查找所需页在磁盘上的位置2.查找一空闲帧n如果有空闲帧,那么就使用它n如果没有空闲帧,那么就使用页置换算法以选择一个“牺牲”帧(victim frame)。n将“牺牲”帧的内容写到磁盘上;改变页表和帧表。3.将所需页读入(新)空闲帧;改变页表和帧表4.重启用户进程。28页置换29n如果没有空闲帧,那么需要两个页传输,将页错误处理时间加倍,相
17、应地增加了有效访问时间n使用修改位(脏位)来降低页传输的开销 只有被修改过的页才写回至磁盘。n页置换分开了逻辑内存与物理内存 采用这种机制,小的物理内存能为程序员提供巨大的虚拟内存。30实现按需调页需要解决的问题n帧分配算法n决定为每个进程各分配多少帧n页置换算法n需要页置换时,选择要置换的帧31页置换算法n追求最低的页错误率n通过运行一特殊字符串(引用串,reference string)来检验算法,计算其页错误率n针对某一特定引用串和页转换算法,为了确定页错误的数量,还需要知道可用帧的数量。n为了讨论页转换算法,将采用以下引用串,而可用帧的数量为3n7,0,1,2,0,3,0,4,2,3,
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 操作系统 ppt 课件
限制150内