【计算机操作系统】存储管理

目录

内存的分配和回收

虚拟内存的原理和实现

页面置换算法

内存保护和地址转换


内存的分配和回收

在操作系统中,内存管理是一个重要的功能,它负责管理计算机内存的分配和回收。下面是内存分配和回收的几种方式:

1. 伙伴系统分配法:该方法将可用内存分成大小相等的块,并按照2的幂次方分成不同的级别。当需要分配内存时,系统会寻找合适的级别,并分配对应大小的内存。当需要回收内存时,系统会将该内存块合并为一个更大的块,然后继续寻找下一个级别的内存块,进行合并,直到找不到可以合并的块为止。

2. 段式存储管理:该方法将内存分成不同的段,每个段有自己的大小和属性。当需要分配内存时,系统会分配一个或多个连续的段。当需要回收内存时,系统会将该段标记为可用状态,并添加到空闲列表中。

3. 页式存储管理:该方法将内存分成固定大小的页框,并将物理内存和逻辑内存之间进行映射。当需要分配内存时,系统会将逻辑地址转换为物理地址,并分配对应大小的页框。当需要回收内存时,系统会将对应的页框标记为可用状态,并添加到空闲列表中。

4. 段页式存储管理:该方法将内存分成不同的段,并将每个段分成固定大小的页框。当需要分配内存时,系统会先分配一个段,然后在该段内分配一个或多个页框。当需要回收内存时,系统会将对应的页框标记为可用状态,并添加到空闲列表中,如果一个段中所有页框都被回收,系统会将该段标记为可用状态,并添加到空闲列表中。

以上是几种常用的内存分配和回收方式,不同的操作系统可以选择不同的方式来管理内存,根据应用场景和实际需求进行选择。

虚拟内存的原理和实现

虚拟内存是一种将主存和磁盘存储器结合起来使用的技术,它可以使得进程访问的地址空间不受主存的大小限制,从而提高了系统的使用效率和性能。

虚拟内存的实现原理:

1. 页面分配:虚拟内存被划分为大小相等的页面,页面是虚拟内存的基本单位,它的大小通常为4KB或者8KB,每个页面都有唯一的标识符(Page ID)。

2. 页面映射:页面映射是指将虚拟页面映射到物理页面上,建立虚拟地址到物理地址的映射关系。操作系统通过页表来管理虚拟内存和物理内存之间的映射关系。

3. 页面置换:当主存不足时,操作系统需要将一些不常用的页面移出到磁盘上,以腾出空间给新的页面使用。这个过程叫做页面置换。操作系统通过页面置换算法来选择哪些页面需要被置换。

4. 页面保护:操作系统通过对每个页面的读写权限进行设置,来保护不同进程的地址空间不被相互访问和修改。

虚拟内存的实现过程:

1. 当一个进程需要访问一个虚拟地址时,操作系统先检查页表,找到对应的物理地址,如果物理页面已经在主存中,那么直接访问该物理页面;否则,就需要将该页面从磁盘中读入到主存中,然后再访问该物理页面。

2. 当主存不足时,操作系统会将一些不常用的页面移出到磁盘上,以腾出空间给新的页面使用。

虚拟内存的优点:

1. 提高了系统的使用效率和性能:虚拟内存可以将主存和磁盘存储器结合起来使用,使得进程访问的地址空间不受主存大小的限制。

2. 更好的内存管理:虚拟内存可以对内存进行更好的管理和保护,提高了系统的稳定性和安全性。

3. 多任务支持:虚拟内存可以为多个进程提供独立的地址空间,避免了进程之间的干扰。

虚拟内存的缺点:

1. 页面置换的开销:由于虚拟内存需要将不常用的页面从主存中置换到磁盘中,因此会增加一定的开销。

2. 系统开销:虚拟内存需要维护页表等数据结构,因此会增加一定的系统开销。

页面置换算法

页面置换算法是操作系统中用于处理虚拟内存的算法。在虚拟内存中,进程并不总是需要访问所有的内存数据,因此操作系统可以将部分数据放入磁盘上的交换空间中,从而释放内存空间以供其他进程使用。当进程需要访问磁盘中的某个页面时,操作系统会将该页面载入内存,并选择一个页面进行替换。页面置换算法就是用于选择被替换的页面的算法。

常见的页面置换算法包括:

1. 先进先出算法(FIFO):选择最早进入内存的页面进行替换。
2. 最近最久未使用算法(LRU):选择最近最久未被访问过的页面进行替换。
3. 最不常用算法(LFU):选择最不常被访问的页面进行替换。
4. 时钟算法(Clock):将所有页面组织成一个环形链表,每个页面带有一个访问位(表示是否被访问过),指针指向最近访问的页面,当需要替换页面时,从指针指向的页面开始,找到第一个访问位为0的页面进行替换,同时将指针指向下一个页面。

这些算法各有优缺点,选择合适的置换算法需要根据具体的应用场景和系统特性进行评估和选择。

内存保护和地址转换

内存保护和地址转换是操作系统中非常重要的概念。在计算机系统中,由于存在多个进程或应用程序同时运行,每个进程或应用程序都需要独立的内存空间,而操作系统需要对每个进程或应用程序的内存访问进行控制和保护,防止非法进程或应用程序访问其他进程或应用程序的内存,从而保障系统的安全性和稳定性。

内存保护是指操作系统通过各种手段,保障系统内存不被恶意程序所篡改、破坏,确保系统数据和程序的安全。常见的内存保护方式有以下几种:

1. 地址访问检查:操作系统通过检查每个内存访问请求的地址,来保护系统的内存安全。

2. 存储保护机制:操作系统在内存中为每个进程分配一定的内存空间,使用一些硬件和软件机制,防止一个进程访问另一个进程的内存空间。

3. 权限位:操作系统为每个进程分配一个权限位,限制进程对内存空间的访问权限。

地址转换是指将逻辑地址转换为物理地址的过程,实现进程地址空间的隔离。当一个进程需要访问内存时,操作系统需要将该进程的逻辑地址转换为实际的物理地址。在现代操作系统中,地址转换是通过硬件和操作系统共同完成的。

在操作系统中,地址转换的过程通常包括以下几个步骤:

1. 逻辑地址生成:进程访问内存时,产生的地址称为逻辑地址。

2. 段式地址转换:操作系统中,通常采用段式地址转换的方式,将逻辑地址分为段号和段内偏移量两部分,通过查找段表,将逻辑地址转换为线性地址。

3. 页式地址转换:将线性地址转换为物理地址。页式地址转换将线性地址划分为页号和页内偏移量两部分,通过查找页表,将页号转换为物理地址的页框号,再将页框号和页内偏移量组合成物理地址。

内存保护和地址转换是操作系统中非常重要的概念,涉及到进程的隔离和内存访问的安全。操作系统通过各种手段,保障系统内存不被恶意程序所篡改、破坏,确保系统数据和程序的安全,同时通过地址转换,实现进程地址空间的隔离。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值