存储器的功能需求

  • 容量足够大
  • 速度足够快
  • 信息永久保存
  • 多道程序并行

多道程序并行带来的问题

  1. 共享:代码和数据共享,节省内存
  2. 保护:不允许内存中的程序相互间非法访问

实际存储器体系

  • 三级存储体系

  • Cache(快、小、贵)+内存(适中)+辅存(慢、大、廉)
  • 基本原理
    • 当内存太小不够用时,用辅存来支援内存
    • 暂停不运行的模块换出到辅存上,必要时再换入内存

存储管理的功能

  1. 地址映射
  2. 虚拟存储
  3. 内存分配
  4. 存储保护

存储管理的功能1:地址映射

定义

  • 把程序中的地址(虚拟地址/虚地址/逻辑地址)变换成内存的真实地址(实地址/物理地址)的过程
  • 地址重定位,地址重映射

方式

  1. 固定地址映射
  2. 静态地址映射
  3. 动态地址映射

固定地址映射

定义:编程或编译时确定逻辑地址和物理地址的映射关系

特点

  • 程序加载时必须放在指定的内存区域
  • 容易产生地址冲突,运行失败

静态地址映射

定义:程序再装入时由操作系统完成逻辑地址到物理地址的映射

静态地址映射

  • 逻辑地址:VA(Virtual Addr.)

  • 装入基址:BA(Base Addr.),程序装在内存中的起始地址

  • 物理地址:MA(Memory Addr.)

    MA = BA + VA

例子:

MA = x + BA

  • 逻辑地址:VA=X,(X) = 1234
  • 装入基址:BA
  • MA = X + BA

特点

  • 程序运行之前确定映射关系
  • 程序装入后不能移动
    • 如果移动必须放回原来位置
  • 程序占用连续的内存空间

动态地址映射

定义:程序在执行过程中把逻辑地址转换为物理地址

​ 例如:MOV AX, [500];访问500单元时执行地址转换

映射过程

  • MA = BA + VA

  • 逻辑地址:VA(Virtual Addr.)

  • 装入基址:BA(Base Addr.)

  • 物理地址:MA(Memory Addr.)

    • 注意:如果程序有移动,BA可能会有改变,自动计算新的MA。

特点:

  1. 程序占用的内存空间可动态变化

    • 要求及时更新基址BA
  2. 程序不要求占用连续的内存空间
    • 每段放置基址BA系统应该知道
  3. 便于多个进程共享代码
    • 共享代码作为独立的一段存放

缺点

  1. 硬件支持(MMU:内存管理单元)
  2. 软件复杂

存储管理的功能2:虚拟存储

解决的问题

  1. 程序过大或过多时,内存不够,不能运行
  2. 多个程序并发时地址冲突,不能运行

虚拟内存的概念

虚拟内存时面向用户的虚拟封闭存储空间(每个进程都有,但是各个都不相关)

  • 线性地址空间
  • 容量4G = \(2^{32}\)Byte
  • 封闭空间(进程空间)
  • 和物理地址分离(地址无冲突
  • 程序员编程时使用现性虚拟地址

虚拟内存管理的目标

  1. 使得大的程序能在较小的内存中运行
  2. 使得多个程序能在较小的内存中运行(/能容纳下)
  3. 使得多个程序并发运行时地址不冲突(/方便、高效)
  4. 使得内存利用效率高:无碎片,共享方便

存储管理的功能3:内存分配功能

为程序运行分配足够的内存空间

需要解决的问题

  1. 放置策略:程序调入内存时将其放置在哪个/哪些内存区
  2. 调入策略:何时把要运行的代码和要访问的数据调入内存
  3. 淘汰策略:内存空间不够时,迁出(/淘汰)那些代码或数据以腾出内存

存储管理的功能4:存储保护功能

保证在内存中的多道程序只能在给定的存储区域活动并互不干扰。

  • 防止访问越界
  • 防止访问越权

方法:界址寄存器

在CPU中设置一对下限寄存器和上限寄存器存放程序在内存中的下限地址和上限地址,程序访问内存时硬件自动将目的地址与这两对寄存器中存放的地址界限比较,判断是否越界。

【av68676164(p41-p42)】内存管理功能的更多相关文章

  1. Linux内核之内存管理完全剖析

    linux虚拟内存管理功能 ? 大地址空间:? 进程保护:? 内存映射:? 公平的物理内存分配:? 共享虚拟内存.实现结构剖析   (1)内存映射模块(mmap):负责把磁盘文件的逻辑地址映射到虚拟地 ...

  2. 理解CPU内存管理

    概述:从设计层面理解CPU的内存模式,包括段式内存管理.页式内存管理以及虚拟化扩展内存管理.实际上,硬件支持与软件实现从来就不是能分开讲的,比如,Intel CPU架构师在选择CPU的硬件特性时,必然 ...

  3. 内存管理概述、内存分配与释放、地址映射机制(mm_struct, vm_area_struct)、malloc/free 的实现

    http://blog.csdn.net/pi9nc/article/details/23334659 注:本分类下文章大多整理自<深入分析linux内核源代码>一书,另有参考其他一些资料 ...

  4. Qt的内存管理

    在QT的程序中经常会看到只有new而不delete的情况,其实是因为QT有一套回收内存的机制,主要的规则如下: 1.所有继承自QOBJECT类的类,如果在new的时候指定了父亲,那么它的清理时在父亲被 ...

  5. MFC与Qt的内存管理

    最近在做MFC向Qt的移植,在内存管理方面遇到了很头疼的问题,虽然不知道问题到底出在哪,先了解下这两个库的内存管理方式.于是转载两篇关于内存管理的文章. 一. Qt内存管理: 在Qt的程序中经常会看到 ...

  6. 内存管理之三——Cocos2d-x学习历程(七)

    1.容器---2.0版本 Cocos2d-x引擎为我们提供了CCArray.CCDictionary等Objective-C风格的容器.使用Cocos2d-x容器的一个重要原因在于Cocos2d-x的 ...

  7. U-Boot内存管理

    如<Linux内核内存管理架构>一文中提到,linux内核中的内存管理支持内存地址映射.内存分配.内存回收.内存碎片管理.页面缓存等众多功能.但U-Boot做为启动引导程序,其核心功能就是 ...

  8. oracle基础——内存管理、优化

    内存图解: 自动管理:11g:AMM   10g:ASMM SGA(system global area):由所有服务进程和后台进程共享 PGA(program global area): 由每个服务 ...

  9. Oracle 自己主动内存管理 SGA、PGA 具体解释

    ASMM自己主动共享内存管理: 自己主动依据工作量变化调整 最大程度地提高内存利用率 有助于消除内存不足的错误 SYS@PROD>show parameter sga NAME          ...

随机推荐

  1. Java实现 LeetCode第30场双周赛 (题号5177,5445,5446,5447)

    这套题不算难,但是因为是昨天晚上太晚了,好久没有大晚上写过代码了,有点不适应,今天上午一看还是挺简单的 5177. 转变日期格式   给你一个字符串 date ,它的格式为 Day Month Yea ...

  2. vue 仿掘金评论列表

    先来个最终效果 代码: template代码: <template> <div class="main"> <div class="titl ...

  3. C++中类继承public,protected和private关键字作用详解及派生类的访问权限

    注意:本文有时候会用Visual Studio Code里插件的自动补全功能来展示访问权限的范围(当且仅当自动补全范围等价于对象访问权限范围的时候),但是不代表只要是出现在自动补全范围内的可调用对象/ ...

  4. bzoj3378[Usaco2004 Open]MooFest 狂欢节*

    bzoj3378[Usaco2004 Open]MooFest 狂欢节 题意: n只奶牛,第i只听力为vi,坐标为xi,两只奶牛聊天时音量是max(vi,vj)*abs(xi-xj).求n(n-1)/ ...

  5. OSCP Learning Notes - Kali Linux

    Install Kali Linux : https://www.kali.org/ Common Commands: pwd man ls ls -la cd mkdir rmdir cp mv l ...

  6. P4554 小明的游戏 (洛谷) 双端队列BFS

    最近没有更新博客,全是因为英语,英语太难了QWQ 洛谷春令营的作业我也不会(我是弱鸡),随机跳了2个题,难度不高,还是讲讲吧,学学新算法也好(可以拿来水博客) 第一题就是这个小明的游戏 小明最近喜欢玩 ...

  7. 性能测试必备知识(4)- 使用 stress 和 sysstat

    做性能测试的必备知识系列,可以看下面链接的文章哦 https://www.cnblogs.com/poloyy/category/1806772.html stress 介绍 Linux 系统压力测试 ...

  8. python 列表的创建以及基本操作

    <python编程从入门到实践> 第三章 列表简介 用"[]"来建立列表,例如:letter = [a,b,c]; 用"[]"来提取列表元素,例如l ...

  9. noi linux gedit 配置(c++环境)

    基本配置 方法一 查看所有命令: gsettings list-recursively | grep -i gedit 命令解释 gsettings set org.gnome.gedit.prefe ...

  10. leetcode题库练习_左旋转字符串

    题目:左旋转字符串 字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部.请定义一个函数实现字符串左旋转操作的功能.比如,输入字符串"abcdefg"和数字2,该函数将返 ...