操作系统学习笔记(二)

Updated December 25, 2018

存储器管理

可执行存储器: 寄存器和主存储器
主存储器: 简称内存或主存. 通常, 处理机都是从主存储器中取得指令和数据的, 并将其取得的指令放入指令寄存器中, 将其所读取的数据装入到数据寄存器中.
高速缓存: 它是介于寄存器和主存储器之间的存储器, 主要用于备份主存中较常用的数据, 以减少处理机对主存储器的访问次数, 这样可提高程序执行速度.
从写程序到运行程序

  1. 编译: 源代码编译成若干个目标模块(编译就是把高级语言翻译成机器语言)
  2. 链接: 将一组目标模块以及所需库函数链接在一起, 形成一个完整的装入模块
  3. 装入: 将装入模块装入内存运行

装入的3种方式:

  1. 绝对装入: 程序中所使用的绝对地址既可在编译或汇编时给出, 也可由程序员直接赋予. 绝对装入只适用于单道程序环境.
  2. 静态重定位: 又称可重定位装入, 把在装入时对目标程序中指令和数据地址的修改过程称为重定位. 又因为地址变换通常是在进程装入时一次完成, 以后不再改变, 故称为静态重定位. 静态重定位不允许程序运行时在内存中移动位置.
  3. 动态重定位: 又称动态运行时装入, 装入程序在把装入模块装入内存后, 并不立即把装入模块中的逻辑地址转换为物理地址, 而是把地址转换推迟到程序真正要执行时才进行. 为使地址转换不影响指令的执行速度, 这种方式需要一个重定位寄存器的支持.

链接的3种方式:

  1. 静态链接: 在程序运行之前, 先把各目标模块及它们所需的库函数连接成一个完整的可执行文件, 之后不再拆开
  2. 装入时动态链接: 在装入内存时, 采取边装入边链接的链接方式. 优点是便于修改和更新, 便于实现对目标模块的共享.
  3. 运行时动态链接: 将对某些模块的链接推迟到程序执行时才进行. 优点是加快程序的链接过程, 节省内存空间

连续分配方式: 指为用户进程分配的必须是一个连续的内存空间

  1. 单一连续分配: 内存被分为系统区和用户区, 而在用户区内存中只能有一道用户程序
  2. 固定分区分配: 将整个用户区内存划分为若干个固定大小的分区, 在每个分区中只装入一道作业.
  3. 动态分区分配: 又称可变分区分配, 在实现动态分区分配时, 将涉及到分区分配中所用的数据结构, 分区分配算法和分区分配回收这样三方面的问题

基于顺序搜索的动态分区分配算法

  1. 首次适应(first fit)算法
    空闲分区以地址递增的顺序排列. 每次分配内存时顺序查找空闲分区链/空闲分区表, 找到大小能满足的第一个分区. 该算法保留了高址部分的大空闲区, 缺点是低址部分不断被划分, 会留下很多碎片.
  2. 循环首次适应(next fit)算法
    next fit算法在为进程分配内存空间时, 不是每次都从链首开始查找, 而是从上次找到的空闲分区的下一个空闲分区开始查找.
  3. 最佳适应(best fit)算法
    空闲分区以容量递增的顺序排列. 每次分配内存时顺序查找空闲分区链/空闲分区表, 找到大小能满足的第一个分区. 缺点是会留下很多碎片.
  4. 最坏适应(worst fit)算法
    与最佳适应算法相反, 对中, 小作业有利

基于索引搜索的动态分区分配算法

  1. 快速适应(quick fit)算法
  2. 伙伴系统(buddy system)
  3. 哈希算法
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. 基础知识 1.1、 基本概念、 功能 冯诺伊曼体系结构1、计算机处理的数据和指令一律用二进制数表示2、顺序执...
    yunpiao阅读 5,452评论 1 22
  • # 第一章复习题答案p3 1、计算机系统由哪些部分组成? 2、什么是计算机的操作系统?答:操作系统是计算机的一种系...
    叛逆闲人阅读 3,449评论 0 0
  • 一、温故而知新 1. 内存不够怎么办 内存简单分配策略的问题地址空间不隔离内存使用效率低程序运行的地址不确定 关于...
    SeanCST阅读 7,894评论 0 27
  • 生活需要一些仪式感,教育更需要仪式感。 李虹霞老师分享了这样一个小故事:她来北京中关村三小后接手了一年级一个班,在...
    冯展奎阅读 379评论 1 13
  • 26岁以后,在选择护肤品上我就开始注重添加抗衰老成分的产品,借以对抗日渐猥琐的地心引力。 最近,又在考虑入手口服胶...
    万年修得王小顺阅读 508评论 4 9