计算机操作系统--哈工大(3)
创始人
2024-06-02 05:12:20
0

多级页表与快表

2^20是地址映射的个数,即1MB,假设每一个映射需要4个字节,那么每个页表就是4MB

每个进程都需要自己的页表,所以10个进程页表就需要40MB

实际上大部分逻辑地址根本用不到

这部分终于搞懂每个数字表达什么了,感谢老师TAT

尝试一,只存放用到的页

用到的页才有页表项

但是页表中的页号不连续,所以需要比较查找折半,log(2^20)= 20,二分查找的前提是排序好的

速度会慢

尝试二,多级页表

页目录表+页表

时间换空间,空间换时间捏

快表

缓存,硬件设计可以直接根据页号找到,找到了有效的地址就叫做TLB命中

未找到就是TLB未命中,接下来就老老实实查找

程序的地址访问具有局部性,空间局部性

段页结合的实际内存管理 虚拟内存

段页同时存在:段面向用户 页面向硬件

重定位

分配段,建立段表;分配页,建立页表

过程:现在虚拟内存中割出一段空间,假装放进去(记好段表),在物理内存中找到地方,建立页表,用重定位具体的使用内存

fork函数

请求调页与内存换入

用换入换出实现大内存 请求的时候才换入然后建立映射

请求调页

发生缺页时引发中断,页错误处理程序将缺页换入,中断结束(重新执行缺页的那一页的请求)

内存换出

FIFO页面置换 先入先出

MIN算法

选最远将使用的页淘汰,是最优方案(在可预见的未来中最迟需要用到的)

LRU算法:

选最近最长一段时间没有使用的页淘汰(最近使用次数最少)

LRU准确实现 用时间戳

每次选择数字最小的那个淘汰

模拟起来很简单,但是实际放进操作系统中很难(每次地址访问都需要修改时间戳,需要维护一个全局时钟,需要找到最小值.....实现代价太大)

LRU准确实现 用页码栈

LRU近似实现-将时间计数变为是和否

将最近最少使用近似为最近是否使用

当缺页很少时

所有能指到的数字几乎都是1,没有0 .当发生缺页时,指针会转一圈将所有1换成0,然后将第一个被换成0的页牺牲,然后指向第二个页。等下一次发生缺页时又会转一整圈。这时,LRU就会退化为FIFO算法

原因:记录了太长的历史信息

方法:定时清楚R位 再定义一个扫描指针

clock算法

给进程分配多少页框(帧fream)

分配多少页合适? 分配的页数应该可以容纳一个局部

但是局部不好求 有很多求局部(工作集)的算法

相关内容

热门资讯

阿索卡·塔诺为什么没有在星球大... 阿索卡·塔诺为什么没有在星球大战正传出现?阿索卡没有听说过,,是什么鬼阿索卡是阿纳金年轻时收的徒弟 ...
河北公布第二批美丽河湖名单,1... 转自:河北新闻网河北公布第二批美丽河湖名单,15个河湖入选全省美丽河湖总数达26个河北日报讯(记者马...
热血英豪灵异少女带幻影水晶 热血英豪灵异少女带幻影水晶我看见有人用灵异带幻影能幻影出灵异的ZXC,怎么弄的? 是不是他改了...
潍柴:自主锻造“国产引擎” 加... 历时10年,投入1.2亿元,接连突破甲醇发动机抗机油乳化技术、低温冷启动技术、控早燃爆震技术等多项行...
西班牙多地将出现强降雨等极端天... 来源:央视新闻客户端当地时间7月10日,西班牙国家气象局警告称,当地时间11日起,该国多个地区将出现...
来中国前,黄仁勋先去见了特朗普   炒股就看金麒麟分析师研报,权威,专业,及时,全面,助您挖掘潜力主题机会! 【文/观察者网 柳...
警惕虚假宣传诱导网络贷款的风险 转自:中国银行保险报网□本报记者 仇兆燕7月10日,金融监管总局金融消费者权益保护局发布风险提示,提...
比特币突破11.7万美元 续创... .ct_hqimg {margin: 10px 0;} .hqimg_wrapper {text-a...
翼年代记漫画最近章节都说什么了... 翼年代记漫画最近章节都说什么了?OVA《东京默示录》是漫画107话到135话的内容,漫画要从136话...
中国天瑞水泥遭Yu Kuo C... .ct_hqimg {margin: 10px 0;} .hqimg_wrapper {text-a...