LRU算法总结及其C算法实现

 

LRU是关于操作系统的内存管理,如何节省利用容量不大的内存为最多的进程提供资源,一直是研究的重要方向的其中一种算法。在操作系统开发和管理的时候,为了提高内存的使用率,提高内存的性能,就需要使用某种算法来管理。使用扩展内存或者虚拟内存能够极大的方便操作系统对内存的管理和提高内存的能力,也就是常常我们说的虚拟内存了。当程序载入的时候,这个时候操作系统会读取一部分到内存中,一些信息段会存储需要调用的内存在磁盘上的地址。例如一个程序要读文件,在载入时,读文件的方法并没有载入到内存中,当需要读文件时,操作系统可能才把相应的内存给载入到寄存器,这样虽然提高了内存的功能,但是却加大了交互。所以就想到可以设计算法来减少交互,提高效率。LRU就是为了这个需求设计的算法中的一种。

 

链表法:

 

操作系统为每个进程维护一条链表,链表的每个结点记录一张页面的地址。调用一次页面,则把该页面的结点从链中取出,放到链尾;要装入新页,则把链头的页面调出,同时生成调入页面的结点,放到链尾。

链表法可看作简单计时/计数法的改良,维护一个链表,自然要比维护所有页面标志要简单和轻松。可是,这并没有在数量级上改变算法的时间复杂度,每调用一个页面,都要在链表中搜寻对应结点并放至链尾的工作量并不算小。

 

重要算法解释

 

  

编译后,按提示输入页架数与访问序列,回车;运行后,将看到输出结果即页面置换与装入情况。

如此显然要花费较大的系统开销(包括时间和空间上的),这也是实际系统中不直接采用LRU算法作为页面置换算法的直接原因,但由于其在页面置换的优越性,实际系统常使用LRU的近似算法。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值