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

简介:

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

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

链表法:

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

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

重要算法解释

view plaincopy to clipboardprint?
void LRU(page_node head) /LRU算法,用到一个链表,表头为work_head指针指向内存中最久未被访问过的页面,表尾为work_tail指针指向内存中最近被访问过的页面*/
{

page_node *phead,*work_head=NULL,*work_tail,*prenode;   
int i,diseffect=0;   
for(i=0;i<NUM;i++)   
if(page_id_status[page_id[i]]==0)  /*如果第page_id[i]页不在内存则发生页面中断*/  

{     
    if(head!=NULL)    /*内存空间已全部被占用,要求换出一页,即从work_head表头取出一页换出*/  
    {     
        phead=head->next;   
        head->next=NULL;   
        head->id=page_id[i];   
        head=phead;   
    }   
else                 /*内存空间还有部分未被使用,可直接将页面放入,即放在work_head链表尾部即work_tail处*/  

           diseffect++;   
           page_id_status[page_id[i]]=1;   

}   
else                  /*如果第page_id[i]页在内存则调整页面顺序,最近被访问的页面调到链表尾部*/  
{     
    phead=work_head;   
    phead=work_head;   
    while(phead->id!=page_id[i])   
    {   
        prenode=phead;   
        phead=phead->next;   

    }   

    if(phead==work_head)   
        work_head=work_head->next;   

    else if(phead==work_tail)   

        work_tail=prenode;   

    else  

        prenode->next=phead->next;   

    phead->next=NULL;   
    work_tail->next=phead;   
    work_tail=work_tail->next;   
}   
printf("LRU: %d",diseffect);  /*输出页面中断次数*/  

}
void LRU(page_node head) /LRU算法,用到一个链表,表头为work_head指针指向内存中最久未被访问过的页面,表尾为work_tail指针指向内存中最近被访问过的页面*/
{

page_node *phead,*work_head=NULL,*work_tail,*prenode;

int i,diseffect=0;
for(i=0;i if(page_id_status[page_id[i]]==0) /如果第page_id[i]页不在内存则发生页面中断/

{
if(head!=NULL) /内存空间已全部被占用,要求换出一页,即从work_head表头取出一页换出/
{
phead=head->next;
head->next=NULL;
head->id=page_id[i];
head=phead;
}
else /内存空间还有部分未被使用,可直接将页面放入,即放在work_head链表尾部即work_tail处/

  diseffect++;
  page_id_status[page_id[i]]=1;

}
else /如果第page_id[i]页在内存则调整页面顺序,最近被访问的页面调到链表尾部/
{
phead=work_head;
phead=work_head;
while(phead->id!=page_id[i])
{
prenode=phead;
phead=phead->next;

}

if(phead==work_head)
work_head=work_head->next;

else if(phead==work_tail)

work_tail=prenode;

else

prenode->next=phead->next;

phead->next=NULL;
work_tail->next=phead;
work_tail=work_tail->next;
}
printf("LRU: %d",diseffect); /输出页面中断次数/

}

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

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

本文来自CSDN博客,转载请标明出处:file:///D:/500g硬盘的桌面,待清理/LRU算法总结及其C算法实现%20-%20XGuru's%20窝%20-%20CSDN博客.htm
本文转自jiahuafu博客园博客,原文链接http://www.cnblogs.com/jiahuafu/archive/2010/12/01/1892621.html如需转载请自行联系原作者

jiahuafu

相关文章
|
3月前
|
算法
操作系统LRU算法(最近最少使用算法)
操作系统LRU算法(最近最少使用算法)
22 0
|
4月前
|
算法 NoSQL Java
Apache Zeppelin系列教程第八篇——LRU算法在Apache Zeppelin中的应用
Apache Zeppelin系列教程第八篇——LRU算法在Apache Zeppelin中的应用
32 0
|
1月前
|
存储 缓存 算法
从0开始回顾数据结构---LRU,LFU算法
题意解释 请为LFU缓存设计一个数据结构。支持两种操作:get和set。 ● get(key) : 如果key在缓存中,则返回key对应的值;否则返回-1; ● put(key, value): 如果key在缓存中,则更新key对应的值;否则插入(key, value),如果缓存已满,则先删除使用频率最小的key,如果有多个key具有相同的使用频率,则应该删除最久未使用的key。 C++代码 class LFUCache { public: struct Node { Node *left, *right; int key, val;
|
3月前
|
缓存 算法 NoSQL
Redis 为何使用近似 LRU 算法淘汰数据,而不是真实 LRU?
Redis 为何使用近似 LRU 算法淘汰数据,而不是真实 LRU?
29 0
|
3月前
|
存储 缓存 算法
数据结构与算法面试题:实现一个 LRU 缓存,支持如下操作:获取值、更新值、删除键值对和插入键值对
数据结构与算法面试题:实现一个 LRU 缓存,支持如下操作:获取值、更新值、删除键值对和插入键值对
28 0
|
3月前
|
存储 缓存 算法
【算法与数据结构】LRU 算法
LRU(Least Recently Used),这种算法认为最近使用的数据是热点数据,下一次有很大概率会再次使用这个数据。而最近很少被使用的数据,很大概率下一次不会使用。所以当缓存容量满时,优先淘汰掉最近最少使用的数据。
|
4月前
|
存储 缓存 算法
☆打卡算法☆LeetCode 146. LRU 缓存 算法解析
☆打卡算法☆LeetCode 146. LRU 缓存 算法解析
|
30天前
|
传感器 算法 计算机视觉
基于肤色模型和中值滤波的手部检测算法FPGA实现,包括tb测试文件和MATLAB辅助验证
该内容是关于一个基于肤色模型和中值滤波的手部检测算法的描述,包括算法的运行效果图和所使用的软件版本(matlab2022a, vivado2019.2)。算法分为肤色分割和中值滤波两步,其中肤色模型在YCbCr色彩空间定义,中值滤波用于去除噪声。提供了一段核心程序代码,用于处理图像数据并在FPGA上实现。最终,检测结果输出到&quot;hand.txt&quot;文件。
|
1月前
|
机器学习/深度学习 算法 计算机视觉
基于yolov2深度学习网络的视频手部检测算法matlab仿真
基于yolov2深度学习网络的视频手部检测算法matlab仿真
|
1月前
|
算法
【MATLAB】语音信号识别与处理:移动中位数滤波算法去噪及谱相减算法呈现频谱
【MATLAB】语音信号识别与处理:移动中位数滤波算法去噪及谱相减算法呈现频谱
23 2

热门文章

最新文章