文章目录
前言
此篇文章是我在B站学习时所做的笔记,大部分图片都是课件老师的PPT,方便复习用。此篇文章仅供学习参考。
提示:以下是本篇文章正文内容
知识总览
操作系统作为系统资源的管理者,当然也需要对内存进行管理,要管些什么呢?
- 操作系统负责内存空间的分配与回收
- 操作系统需要提供某种技术从逻辑上对内存空间进行扩充
- 操作系统需要提供地址转换功能,负责程序的逻辑地址与物理地址的转换
- 操作系统需要提供内存保护功能。保证各进程在各自存储空间内运行,互不干扰
1、内存空间的分配与回收
2、内存空间的扩展
3、地址转换
为了使编程更方便,程序员写程序时应该只需要关注指令、数据的逻辑地址。而逻辑地址到物理地址的转换(这个过程称为地址重定位)应该由操作系统负责,这样就保证了程序员写程序时不需要关注物理内存的实际情况。
地址重定位的实现是用三种装入方式:
绝对装入中的绝对地址的转换是由编译器来完成的,而不是由操作系统来完成的
可重定位装入也叫静态重定位,这个转换过程是由装入程序负责的,装入程序也是操作系统的一部分
4、内存保护
解说:
在内存当中一般会分为操作系统使用的内存区域,还有普通的用户程序使用的内存区域,各个进程都会被分配到各自的内存空间,如果进程1想对操作系统的内存空间进行访问的话,很显然这个行为应该被阻止,如果进程1可以随意的更改操作系统的数据,那么很明显会影响整个系统的安全,另外如果进程1想要访问其他进程的存储空间的话,那么显然这个行为也应该被阻止,如果进程1可以随意的修改进程2的数据的话,那么显然进程2的运行就会被影响,这样也会导致系统不安全,所以进程1只能访问进程1自己的那个内存空间,所以这就是内存保护想实现的事情,让各个进程只能访问自己的那些内存空间,而不能访问操作系统的,也不能访问别的进程的内存空间。
方法一:在CPU中设置一堆上、下限寄存器检查进程的地址是否越界
在CPU中设置上限寄存器和下限寄存器,分别用来存储空间的上限和下限,那如果进程1的某一条指令想要访问某一个内存单元的时候,cpu会根据指令当中想要访问的那个内存地址和上下限寄存器的两个地址进行对比,只有在这两个地址之间才允许进程1访问,因为只有这两个地址之间的这个部分,才属于进程1的内存空间。