【av68676164(p48-p50】虚拟内存管理(1)
7.3.1 页式虚拟内存管理概念
物理内存(即实内存)管理
| 特点 | 缺点 | |
|---|---|---|
| 1 | 源程序直接使用内存的物理地址 | 程序间容易访问冲突 |
| 2 | 程序必须全部装入内存才能运行 | 内存太小程序无法运行 |
| 3 | 程序占用连续的一片内存 | 产生内存碎片 |
| 4 | 多程序同时运行容易相互干扰 | 不安全 |
改善物理内存管理的相关技术
- 内存拼接
- 交换技术(Swapping)
- 覆盖技术(Overlay)
虚拟内存管理的目标
- 使得大的程序能在较小的内存中运行
- 使得多个程序能在较小的内存中运行(/能容纳下)
- 使得多个程序并发运行时地址不冲突(/方便、搞笑)
- 使得内存利用效率高:无碎片,共享方便
虚拟内存管理的实现思路
程序运行时,只把当前必要的很小一部分代码和数据装入内存中,其余代码和数据需要时再装入,不再运行的代码和数据及时从内存删除。
实际内存很容易就能满足上述的内存需求。
程序运行的局部性
- 程序在一个有限的时间段哪访问的代码和数据往往集中在有限的地址范围内。
- 把程序一部分装入内存在较大概率上也足够让其运行一小段时间。
典型虚拟内存管理方式
- 页式虚拟内存管理
- 段式虚拟内存管理
- 段页式虚拟内存管理
页式虚拟内存管理
概念
把进程空间(虚拟)和内存空间划成等大小的小片
- 小片的典型大小:1K、2K或4K
- 进程的小片—页
- 内存的小片—页框

- 内存以页框为单位分配使用
- 进程以页为单位装入内存
- 只把程序的部分页装入内存即可运行
- 页在内存中占用的页框不必相邻
- 需要新页时,按需从硬盘掉入内存
- 不再运行的页及时删除,腾出空间

7.3.2 页式和页式地址映射
页式系统中的地址
虚拟地址(VA)可以分解成页号P和页内偏移W
页号(P)
VA所处页对的编号=VA/页的大小
页内偏移(W)
VA所处页的偏移=VA%页的大小
例子
VA=2500;页面大小1K(\(10^{12}\))
W=2500\, \% \,1024 =452
\]
P和W的另一种计算方法(计算机中)
已知
页的大小:\(2^n\)单元
P和W计算
页号\(P=VA>>n\)
页内偏移\(W=低n位=VA\, \&\&\,(2^n-1)\)
页面映射表
记录了页与页框之间的对应关系,也叫页表。

页号:登记程序地址的页号
页框号:登记页所在的物理页号
页面其他特性:登记含存取权限在内的其他特性
页表例子:一个进程、4页

页式地址映射
功能
虚拟地址(页式地址)→物理地址
过程【三步】
从VA分离页号P和页内偏移W
查页表:以P位索引查页框号P'
计算物理地址MA
\(MA=P'\times 页大小 + W\)
页式地址映射的例子
MOVE R1, [2500]
解:
分离P,W
\[P=\frac {VA}{页面大小}=\frac{2500}{1024}=2\\
W=VA\,\%\,页面大小=2500\,\%\,1024=452
\]查找页表
P=2,P'=7

计算\(MA=P'\times 页大小 + W\)
\[MA=7\times1024+452=7620
\]
7.3.3 快表技术和页面共享技术
快表机制(Cache)
快表的概念
- 慢表:页表放在内存中
- 快表:页表放在Cache中
快表的特点
容量小、访问快、成本高
快表是慢表的部分内容的复制
地址映射时优先访问快表
- 若在快表中找到所需数据,则称为“命中”
- 没有命中时,则需要访问慢表,同时更新快表
合理的页面调度策略能使快表具有较高命中率
快表机制下地址映射过程

页面的共享

代码共享的例子—文本编辑器占用多少内存
- 文本编辑器:150KB代码段和50KB的数据段
- 有10进程并发执行该文本编辑器
- \(占用内存=10\times(150+50)KB=2M\)
- 如果采用代码段共享,代码段在内存中只有一份真实存储
- \(占用内存=150+10\times50=650KB\)
页面共享原理
- 在不同进程的页表中填上相同的页框号,多个进程能访问相同的内存空间,从而实现页面共享
- 共享页面在内存中只有一份真实存储,节省内存。

【av68676164(p48-p50】虚拟内存管理(1)的更多相关文章
- 【av68676164(p51-p53)】虚拟内存管理(2)
虚拟内存管理(2) 7.3.4 缺页终端 分级存储体系 cache+内存+辅存 页表扩充-带中断位的页表 页号 页框号 中断位I 辅存地址 访问位 修改位 1 1 0 0 0 1 中断位I-标志该页是 ...
- 十问 Linux 虚拟内存管理 (glibc) (二)
版权声明:本文由陈福荣原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/184 来源:腾云阁 https://www.qclo ...
- SoC嵌入式软件架构设计II:没有MMU的CPU虚拟内存管理的设计和实现方法
大多数的程序代码是必要的时,它可以被加载到内存中运行.手术后,可直接丢弃或覆盖其它代码. 我们PC然在同一时间大量的应用,地址空间差点儿能够整个线性地址空间(除了部分留给操作系统或者预留它用).能够觉 ...
- SoC嵌入式软件架构设计II:否MMU的CPU虚拟内存管理的设计与实现方法
大多数的程序代码是必要的时,它可以被加载到内存中运行.手术后,可直接丢弃或覆盖其他代码.我们PC然在同一时间大量的应用,能够整个线性地址空间(除了部分留给操作系统或者预留它用),能够觉得每一个应用程序 ...
- windows虚拟内存管理
内存管理是操作系统非常重要的部分,处理器每一次的升级都会给内存管理方式带来巨大的变化,向早期的8086cpu的分段式管理,到后来的80x86 系列的32位cpu推出的保护模式和段页式管理.在应用程序中 ...
- OS之内存管理 --- 虚拟内存管理(二)
关于虚拟内存管理之前的请看:OS之内存管理 - 虚拟内存管理(一) 帧分配 每个进程对的最小帧数是由操作系统的体系结构决定的,但是最大帧数是由可用物理内存的数量决定的.所以在这之间,对于进程的帧的分配 ...
- linux内核内存分配(三、虚拟内存管理)
在分析虚拟内存管理前要先看下linux内核内存的具体分配我開始就是困在这个地方.对内核内存的分类不是非常清晰.我摘录当中的一段: 内核内存地址 ============================ ...
- Linux的虚拟内存管理-如何分配和释放内存,以提高服务器在高并发情况下的性能,从而降低了系统的负载
Linux的虚拟内存管理有几个关键概念: Linux 虚拟地址空间如何分布?malloc和free是如何分配和释放内存?如何查看堆内内存的碎片情况?既然堆内内存brk和sbrk不能直接释放,为什么不全 ...
- Unix系统编程()虚拟内存管理
在之前学到过进程的内存布局中忽略了一个事实:这一布局存在于虚拟文件中. 因为对虚拟内存的理解将有助于后续对fork系统调用.共享内存和映射文件之类的主题阐述,这里还要学习一下有关虚拟内存的详细内容. ...
随机推荐
- 爬虫页面解析 lxml 简单教程
一.与字符串的相互转换 1.字符串转变为etree 对象 import lxml.html tree = lxml.html.fromstring(content) # content 字符串对象 2 ...
- Python并发编程05 /死锁现象、递归锁、信号量、GIL锁、计算密集型/IO密集型效率验证、进程池/线程池
Python并发编程05 /死锁现象.递归锁.信号量.GIL锁.计算密集型/IO密集型效率验证.进程池/线程池 目录 Python并发编程05 /死锁现象.递归锁.信号量.GIL锁.计算密集型/IO密 ...
- web CSS3 实现3D动态翻牌效果
使用纯CSS3 实现翻牌效果 需要注意要给子盒子使用绝对定位,这样两个盒子可以完全重合在一起,需要给父盒子一个 transform-style: preserve-3d;让子盒子翻转时保持3D效果, ...
- P1039 侦探推理(洛谷)
昨天做了一个非常神奇的题,告诉我们做题之前一定要好好检测评测姬! 明明同学最近迷上了侦探漫画<柯南>并沉醉于推理游戏之中,于是他召集了一群同学玩推理游戏.游戏的内容是这样的,明明的同学们先 ...
- Python3 装饰器解析
第6章 函数 6.1 函数的定义和调用 6.2 参数传递 6.3 函数返回值 6.4 变量作用域 6.5 匿名函数(lambda) 6.6 递归函数 6.7 迭代器 6.8 生成器 6.9 装饰器 6 ...
- C#中的类与对象
类:说白了就是类型,是对具体事物的一种抽象总结. 对象:一个具体的事物. 类与对象的关系,类实例化就会得到一个对象,同样一个对象也应该属于某一个类.例如张三这个人,他是一个对象,同时他属于人类,在程序 ...
- 从一次故障聊聊前端 UI 自动化测试
背景 事件的起因在于老板最近的两次"故障",一次去年的,一次最近.共同原因都是脚手架在发布平台发布打包时出错,导致线上应用白屏不可用. 最神奇的是,事后多次 Code Review ...
- 使用SQL语句进行数据复制
使用SQL语句对数据或者表进行复制,一般用于两张表结构相同的时候使用. SQL Server中,如果目标表存在: insert into 目标表 select * from 原表; SQL Serve ...
- 面试题二十二:链表中倒数第k个节点
方法一:双指针法定义两个指针A.B,A先走k-1步后再一起走,直到A.next==null注意: 1.链表为空 2.链表长度小于k 3.k<=0 当题目是求链表的中间节点时,可以两个指针从开头开 ...
- Python数据分析之股票数据
最近股市比较火,我7月初上车了,现在已经下了.中间虽然吃了点肉,但下车的时候都亏进去了,最后连点汤都没喝着. 这篇文章我们就用python对股票数据做个简单的分析.数据集是从1999年到2016年上海 ...