内存

基础知识

什么是内存?

内存是用于存放数据的硬件,程序执行前需要先放到内存中才能被cpu处理

如何区分各个程序的数据是放在什么地方的呢?

对内存的存储单元编地址
内存中的一个一个的房间,就是存储单元
按字节编址,每个存储单元为1字节,即1b,即8个二进制位
字节位16的计算机按字编址,则每个存储单元的大小位1个字,每个字的大小为16个二进制位

常用的数量单位

image-20210821085008363

相对地址又称逻辑地址

绝对地址又称物理地址

image-20210821085633418

装入的三种方式

完成逻辑地址到物理地址的转换

绝对装入

静态重定位

动态重定位

绝对装入

在编译时,如果知道程序将放到内存中的哪个位置,编译程序将产生绝对地址的目标代码。装入程序按照装入模块中的地址,将程序和数据装入内存。

只适用于单道程序环境

因为单道只能运行一个程序

程序中使用的绝对地址,可在编译或汇编时给出,也可由程序员直接赋予。通常情况下都是编译或汇编时再转换为绝对地址。

静态重定位

又称可重定位装入。编译、链接后的装入模块的地址都是从0开始的,指令中使用的地址、数据存放的地址都是相对于起始地址而言的逻辑地址。可根据内存的当前情况,将装入模块装入到内存的适当位置。装入时对地址进行“重定位”,将逻辑地址变换为物理地址(地址变换是在装入时一次完成的)。

image-20210821090345139

动态重定位

采用动态重定位允许程序在内存中发生移动

image-20210821090553683

并且可将程序分配到不连续的存储区中;在程序运行前只需装入它的部分代码即可投入运行,然后在程序运行期间,根据需要动态申请分配内存;便于程序段的共享,可以向用户提供一个比存储空间大得多的地址空间。

链接的三种方式

静态链接

在程序运行之前,先将各目标模块及它们所需的库函数连接成一个完整的可执行文件(装入模块),之后不再拆开。

要把独立的逻辑地址合成完整的逻辑地址

image-20210821090845211

装入时动态链接

将各目标模块装入内存时,边装入边链接的链接方式。

image-20210821090934853

运行时动态链接

在程序执行中需要该自标模块时,才对它进行链接。其优点是便于修改和更新,便于实现对目标模块的共享。

image-20210821091059541

image-20210821091121668

内存管理

操作系统负责内存空间的分配与回收

需要提供某种技术从逻辑上对内存空间进行扩充

操作系统需要提供地址转换功能,负责程序的逻辑地址与物理地址的转换

image-20210821092001956

操作系统需要提供內存保护功能。保证各进程在各自存储空间内运行,互不干扰

image-20210821092222269

image-20210821092414139

image-20210821092430500

覆盖和交换

覆盖技术

就是解决程序大小超过物理内存总和的问题

覆盖技术的思想:将程序分为多个段(多个模块)。常用的段常驻内存,不常用的段在需要时调入内存。

内存中分为一个“固定区”和若干个“覆盖区”。
需要常驻内存的段放在“固定区”中,调入后就不再调出(除非运行结束)

不常用的段放在覆盖区”,需要用到时调入内存,用不到时调出内存

image-20210821095045716

必须由程序员声明覆盖结构,操作系统完成自动覆盖。缺点:对用户不透明,增加了用户编程负担。

只用于早期的操作系统

交换技术

交换(对换)技术的设计思想:内存空间紧张时,系统将内存中某些进程暂时换出外存,把外存中某些已具备运行条件的进程换入内存(进程在内存与磁盘间动态调度)

中级调度(内存调度),就是要决定将哪个处于挂起状态的进程重新调入内存

暂时换出外存等待的进程状态为挂起状态(挂起态, suspend)
挂起态又可以进一步细分为就绪挂起、阻塞挂起两种状态

image-20210821095431874

image-20210821095826906

image-20210821095846682

连续分配管理方式

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

单一连续分配方式

image-20210821100316783

固定分区分配方式

image-20210821100558139

操作系统怎样将记录内存空闲的分布情况

image-20210821100820179

动态分区分配

动态分区分配又称为可变分区分配。这种分配方式不会预先划分内存分区,而是在进程装入内存时,根据进程的大小动态地建立分区,并使分区的大小正好适合进程的需要。因此系统分区的大小和数目是可变的。(eg:假设某计算机内存大小为64MB,系统区8MB,用户区共56MB.)

系统要用什么的数据结构记录内存的使用情况

两种常用的数据结构

空闲分区链

空闲分区表

image-20210821101307557

如何对分区的分配和回收操作

image-20210821101456539

回收问题

image-20210821101744792

image-20210821101835555

image-20210821101911025

image-20210821101939963

动态分区分配没有内部碎片,但由外部碎片

内部碎片:分配给进程的内存区域中,如果没用上

外部碎片:是指内存中的某些空间分区由于太小而难以利用

如果内存中空闲空间的总和本来可以满足某进程的要求,
但由于进程需要的是一整块连续的内存空间,因此这些
“碎片”不能满足进程的需求。
可以通过紧湊(拼湊, Compaction)技术来解决外部碎片。

image-20210821102447605

动态分区分配算法

如果有很多空闲分区都能满足,选择哪个进行分配

首次适应算法

算法思想:每次都从低地址开始査找,找到第一个能满足大小的空闲分区

如何实现:空闲分区以地址递增的次序排列。每次分配内存时顺序査找空闲分区链(或空闲分区表),找到大小能满足要求的第一个空闲分区

image-20210821102918731

最佳使用算法

算法思想:由于动态分区分配是一种连续分配方式,为各进程分配的空间必须是连续的一整片区域。因此为了保证当“大进程”到来时能有连续的大片空间,可以尽可能多地留下大片的家闲区,即,优先使用更小的空闲区。
如何实现:空闲分区按容量递增次序链接。每次分配内存时顺序查找空闲分区链(或空闲分区表),找到大小能满足要求的第一个空闲分区

image-20210821103343757

最坏适应算法

又称最大适应算法( Largest Fit)
算法思想:为了解决最佳适应算法的问题ー一即留下太多难以利用的小碎片,可以在每次分配时优先使用最大的连续空闲区,这样分配后剩余的空闲区就不会太小,更方便使用
如何实现:空闲分区按容量递减次序链接。每次分配内存时顺序查找空闲分区链(或空闲分区表),找到大小能满足要求的第一个空闲分区。

image-20210821103539077

邻近适应算法

算法思想:首次适应算法每次都从链头开始査找的。这可能会导致低地址部分出现很多小的空闲分区,而每次分配査找时,都要经过这些分区,因此也增加了査找的开销。如果每次都从上次査找结束的位置开始检索,就能解决上述问题
如何实现:空闲分区以地址递增的顺序排列(可排成一个循环链表)。每次分配内存时从上次査找结東的位置开始査找空闲分区链(或空闲分区表),找到大小能满足要求的第一个空闲分区。

image-20210821104114693

image-20210821104126836

基本分页存储管理的概念

连续分配:为用户进程分配的必须是一个连续的内存空间。
非连续分配:为用户进程分配的可以是一些分散的内存空间。

image-20210821110348111

image-20210821110552265

image-20210821110757598

image-20210821111052500

image-20210821111101038

image-20210821111533953

页表

image-20210821111734139

为什么每个页表项的长度是相同的,页号是隐藏的?

image-20210821112021877

image-20210821112037836

基本地址变换机构

基本地址变换机构可以借助进程的页表将逻辑地址转换为物理地址。
通常会在系统中设置一个页表寄存器(PTR),存放页表在内存中的起始地址F和页表长度M。进程未执行时,页表的始址和页表长度放在进程控制块(PCB)中,当进程被调度时,操作系统内核会把它们放到页表寄存器中

image-20210821112949645

image-20210821113315035

image-20210821113726996

每个页表项的长度是相同的,页号是“隐含”的

image-20210821113949771

进程页通常是装在连续的内存块中的

image-20210821114042719

具有快表的地址变换机构

是对基本地址变化的改进版本

快表,又称联想寄存器(TLB),是一种访问速度比内存快很多的高速缓冲存储器,用来存放当前访问的若干页表项,以加速地址变换的过程。与此对应,内存中的页表常称为慢表。

image-20210821114830823

引入快表,地址变化过程

image-20210821115030458

image-20210821115240441

image-20210821115333582

两级页表

image-20210821215656619

image-20210821220412648

image-20210821220527228

image-20210821220631684

基本分段存储管理方式

分段

进程的地址空间:按照程序自身的逻辑关系划分为若干个段,每个段都有一个段名(在低级语言中,程序员使用段名来编程),每段从0开始编址

image-20210821224412387

段表

image-20210822074743393

地址变化

image-20210822075119971

分段、分页管理对比

image-20210822075600177

image-20210822075841682

image-20210822080018807

image-20210822080132580

image-20210822080155259

段页式管理方式

image-20210822080517667

image-20210822080602996

image-20210822080811292

image-20210822081116874

image-20210822081758179

image-20210822081817570

posted @ 2021-08-22 08:20  testadm1n  阅读(756)  评论(0编辑  收藏  举报