虚拟存储技术「建议收藏」

虚拟存储技术「建议收藏」一.实现内存扩充的技术:(1)覆盖技术:在程序运行中,在不同时刻把同一个存储区分配给不同程序段和数据段,实现存储区共享。适用于连续存储(单一连续区分配,分区)如图BDG共享一个存储区(三个进程不同时发生),CEFH同理(2)交换技术(对换技术):1.定义:将内存中某进程的的程序和数据(全部或部分)写入外存的交换区,从而腾出内存空间给其他进程使用。2.相关涉及知识

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

一.实现内存扩充的技术:

(1)覆盖技术:

在程序运行中,在不同时刻把同一个存储区分配给不同程序段和数据段,实现存储区共享。适用于连续存储(单一连续区分配,分区)

虚拟存储技术「建议收藏」

如图BDG共享一个存储区(三个进程不同时发生),CEFH同理

(2)交换技术(对换技术):

1.定义:

将内存中某进程的的程序和数据(全部或部分)写入外存的交换区,从而腾出内存空间给其他进程使用。

2.相关涉及知识:

磁盘交换区的管理:

磁盘空间划分为两个部分:文件区和交换区

二者的区别:

(1)存储方式不同:文件区信息已文件形式存放,多采用离散存储;交换区信息按字符流形式存放,多用连续存储。

(2)访问速度不同:文件区是间接地址访问(有目录,形成多级),访问时间较慢,而交换区是直接访问,速度较快。

(3)存储时间不同:文件区适合长久存储,交换区适合存放短期数据。

3.方式:对换作业  , 对换进程。

(3)虚拟存储技术(对换页面/段面)

1.相关背景:

程序的局部性原理:在一个较短的时间内,程序执行中对内存地址的访问往往局限于一个较小的空间上。

按照这一原理,一个进程运行时,可不必将进程全部装载到进程中,只需把当前运行的部分程序和数据放到内存中,随着进程运行的不断推进,其余部分可随时装入,实现小内存运次那个大程序的效果。

2.虚拟存储的主要特点:

(1)离散性  (装入虚拟存储的进程以离散形式存放)

(2)多次性(任意进程或其中的一部分可以分多次装载到进程中)

(3)对换性(根据需要进程可以换进换出)

(4)虚拟性(虚拟出一个较大的逻辑空间)

3.虚拟存储的实现:

一.请求分页存储管理:

#1.数据结构:

位示图

页表

(结构)   :    页号 状态(存在位) 帧号 外存位置 访问标识 修改位

若状态位(存在位)为0,说明缺页,则记录该缺页在外存中的位置,访问情况及修改情况。

#2.地址重定位过程:

(1)不发生缺页时:

当调度一个进程时,系统将其页表首址装入CPU中的页表控制寄存器。运行中用相对地址的高端部分作为页号去检索页表,看该页是否已在内存。若已在内存就按普通分页机制的方式直接生成物理地址,并将访问标志和修改标志设置好。

(2)发生缺页时:
若该页不在内存中,则发生缺页中断,通过中断处理机制将缺页调入到内存中。

中断处理过程:

(1) 保留进程上下文。

(2) 判断内存是否有空闲帧?若有,则获取一个帧号No,转(4)。

(3) 腾出一个空闲帧,即:

 (3)-1调用置换算法,选择一个淘汰页PTj。

                   (3)-2  PTj (S)0;

                   (3)-3  No PTj (F);。

                   (3)-4 若该页曾修改过,则:

                           (3)-4-1 请求外存交换区上一个空闲块B。

                           (3)-4-2  PTj (D)B。

                           (3)-4-3 启动I/O管理程序,将该页写到外存上。

 (4)按页表中提供的缺页外存位置,启动I/O,将缺页装入空闲帧中。

 (5)修改页表的状态字段。PTi(F)No;PTi(S)1。

 (6)结束。

虚拟存储技术「建议收藏」

涉及到缺页调入,则要考虑到缺页调入策略:

页面置换算法

主要有6种:

(1)最佳置换算法(OPT):(理想状态下)

思想:每次选择在给出的页号序列中最城市间不再使用的页面置换出去。

(2)先进先出算法:

将最先进来的页调换出去,可以用栈,用栈底保存最开始的值,每次置换都换底。

(3)最近最久未使用算法(LRU):

将最近最久未使用的页面置换出去,若用栈,则在(2)方法的基础上还要每次都要更新栈顶,相关的栈底也会改变

(4)最近最经常不使用(LFU)

(5)Clock(钟表)算法(近似LRU算法(NRU))

该算法中将被置换的候选帧集合构成一个环状缓冲区,并设一个循环移动指针。初始时,该指针指向缓冲区的头部。当某页被选择置换后,指针将顺序指向缓冲区的下一个帧。环状缓冲区中的每个候选帧关联一个“访问位”,记作A,当某帧的A=0时,说明该帧最近未被访问。显然,一个刚刚调入页面的帧,以及刚刚访问过的帧,其A=1。

(6)改进的clock算法:

为每个帧增设一个关联的修改位

A=0且M=0:该帧中所存的页面最近没有访问,也没有修改。

  l  A=1且M=0:该帧中所存的页面最近访问过,但没有修改。

  l  A=0且M=1:该帧中所存的页面最近没有访问,但修改了。

  l  A=1且M=1:该帧中所存的页面最近访问过,也修改过。

页面调入策略:

(1)从文件区调入

(2)从交换区调入

(3)从内存中的磁盘交换区调入

系统的有效访存时间T的估算

•假定系统的一个内存周期为ma,调入缺页的时间为la,缺页率为p,那么:

       T=(1-p)´ma + p ´(la+ ma)

           = ma- p´ma + p´la + p´ma

           = ma +p ´ la.

二.请求分段存储管理:

#1.数据结构:

段表

(结构)    段号   驻留位    内存基址   外存地址   长度   访问权限   访问位   修改位    增补位   



版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/189235.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • yuicompressor java_YUI Compressor[通俗易懂]

    yuicompressor java_YUI Compressor[通俗易懂]简介根据雅虎卓越性能团队的说法,40%到60%的雅虎用户拥有空闲缓存体验,所有页面浏览量中约有20%是使用空缓存完成的(请参阅TenniTheurer在YUIBlog上的这篇文章)有关浏览器缓存使用的更多信息)。这一事实概述了保持网页尽可能轻量化的重要性。改进页面或Web应用程序的工程设计通常会带来最大的节省,而且应始终是主要策略。通过正确的设计,有许多提高性能的辅助策略,例如缩小代码,HTTP…

    2022年7月18日
    15
  • 源码大全_怎么复制网页源代码

    源码大全_怎么复制网页源代码7000个源码批量下载7000个源码批量下载<type=”text/javascript”language=”JavaScript”>document.title=”7000个源码批量下载-“+document.titlehttp://asp.lt263.com/soft/SaGuestBook.rar安全天使字符界面留言本(SaGuestBook)htt…

    2022年10月8日
    3
  • 互联网金融学习总结(5)——市场主流的风控模型简要学习总结

    互联网金融学习总结(5)——市场主流的风控模型简要学习总结分享一个大神的人工智能教程。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到人工智能的队伍中来!点击浏览教程一、市场调研目前市面主流的风控模型1、互联网金融前10名排行榜(数据截止日期2017-09-12)互联网金融公司排名分别是蚂蚁金服、陆金所、京东金融、苏宁金融、百度金融、腾讯理财通、宜信、钱大掌柜、万达金融和网易理财。1.1蚂蚁金服1.1.1大数据技术对…

    2022年5月22日
    65
  • C语言字符串分割

    C语言字符串分割在C语言中,内置的函数库中除了可以用strtok()来对字符串进行分割之外,还可以用sscannf()对字符串进行分割。sscanf()包含的头文件stdio.h原型intsscanf(constchar*str,constchar*format,…)实例:#include&lt;stdio.h&gt;intmain(){ charbuf[]="…

    2022年4月30日
    56
  • httprunner(11)运行测试报告「建议收藏」

    httprunner(11)运行测试报告「建议收藏」前言受益于pytest的集成,HttpRunnerv3.x可以使用pytest所有插件,包括pytest-html和allure-pytest,也可以实现这2种方式的报告内置html报告pyt

    2022年8月6日
    4
  • 流水线设计方案_与流水线的形式相对的叫什么

    流水线设计方案_与流水线的形式相对的叫什么流水线设计是一种典型的面积换性能的设计。一方面通过对长功能路径的合理划分,在同一时间内同时并行多个该功能请求,大大提高了某个功能的吞吐率;另一方面由于长功能路径被切割成短路径,可以达到更高的工作频率,如果不需要提高工作频率,多出来的提频空间可以用于降压降功耗。流水线设计是完美的时间并行。因为流水线上每一级的处理都是一个时钟周期的延时,并且一动则全动,每一级的延时可以完美的掩盖起来,最高实现与流水级数相同数量的请求并行度。流水线实际上是将组合逻辑系统分割,然后在间隙插入寄存器,暂存中间数据。其思想就是要将

    2022年8月14日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号