PHP实现LRU算法的原理详解

 更新时间:2022年03月27日 17:14:44   作者:php_kevlin  
这篇文章主要为大家详细介绍了PHP实现LRU算法的原理,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助

1.概念

LRU : 最近最少使用算法

2.代码

<?php
class Node
{
    public $preKey = null; //链表前一个节点
    public $nextKey = null;  //链表后一个节点
    public $key= null;      //当前的值
    public $value= null;    //当前key

    public function __construct($key,$value){
        $this->key = $key;
        $this->value = $value;
    }

    public function setPre($preKey)
    {
        $this->preKey = $preKey;
    }

    public function setNext($nextKey)
    {
        $this->nextKey = $nextKey;
    }
}

class LRUCache{
    public $cacheTable = [];
    /** Node null  */
    private $headNode = null;
    private $lastNode = null;
    private $cacheCount = 0;
    private $cacheMax = 3;

    public function addNode($key,$value)  //此处采用头插法
    {
        $addNode = new Node($key,$value);
        if ( !empty($this->headNode))
        {
            $this->headNode->preKey = $addNode; //如果链表存在,将节点添加到节点前一个
        }
        $addNode->nextKey = $this->headNode;

        //第一次保存最后一个节点为头结点
        if ($this->lastNode == null){
            $this->lastNode = $addNode;
        }

        $this->headNode = $addNode;
        $this->cacheTable[$key] = $addNode;
        $this->cacheCount++;

    }

    public function set($key,$value)
    {
        //先判断是否需要删除
        $this->shiftNode();
        $this->addNode($key,$value);
        return true;
    }

    //自动删除
    public function shiftNode()
    {
        while ($this->cacheCount >= $this->cacheMax){
            if (!empty($this->lastNode)){
                if ($this->lastNode->preKey){
                    $this->lastNode->preKey->nextKey = null;
                    $this->lastNode = $this->lastNode->preKey;
                }

                unset($this->cacheTable[$this->lastNode->key]);
            }
            $this->cacheCount --;
        }
    }

    public function dumpAllData()
    {
        $node = $this->headNode;
        while (($node)){
            echo "key=".$node->key."value=".$node->value."\n";
            $node = $node->nextKey;
        }
    }

}


$Cache = new LRUCache();
$Cache->set("a","aaaaaaaaaaa");
$Cache->set("b","bbbbbbbbbbb");
$Cache->set("c","ccccccccccc");
$Cache->set("d","dddddddddddd");
$Cache->set("e","eeeeeeeeeeee");
//$Cache->set("f","ffffffffffff");
$Cache->dumpAllData();
//var_dump($Cache);  //是一个深度的数组(对象)



结果

[root@VM-16-13-centos ~]# php LRU.php 
key=evalue=eeeeeeeeeeee
key=dvalue=dddddddddddd
key=cvalue=ccccccccccc

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容!   

相关文章

  • phpstorm断点调试方法图文详解

    phpstorm断点调试方法图文详解

    这篇文章主要介绍了phpstorm断点调试方法,结合图文形式详细分析了phpstorm断点调试的基本配置方法、使用技巧与注意事项,需要的朋友可以参考下
    2023-04-04
  • php中curl和file_get_content的区别

    php中curl和file_get_content的区别

    抓取远程内容,之前一直都在用file_get_content函数,其实早就知道有curl这么一个好东西的存在,但是看了一眼后感觉使用颇有些复杂,没有file_get_content那么简单,再就是需求也不大,所以没有学习使用curl
    2014-05-05
  • php源码分析之DZX1.5字符串截断函数cutstr用法

    php源码分析之DZX1.5字符串截断函数cutstr用法

    这篇文章主要介绍了php源码分析之DZX1.5字符串截断函数cutstr用法,实例分析了DZX1.5中cutstr函数实现字符串截取的使用技巧,需要的朋友可以参考下
    2015-06-06
  • php+mysql查询优化简单实例

    php+mysql查询优化简单实例

    这篇文章主要介绍了php+mysql查询优化简单实例,分析了php+mysql程序设计中关于SQL语句优化查询的技巧,对于提高查询效率有一定参考借鉴价值,需要的朋友可以参考下
    2015-01-01
  • PHP的伪随机数与真随机数详解

    PHP的伪随机数与真随机数详解

    这篇文章主要介绍了PHP的伪随机数与真随机数详解,本文首先讲解了真随机数和伪随机数的相关概念,并给出了比用mt_rand()函数产生更好的伪随机数的一段例子代码,需要的朋友可以参考下
    2015-05-05
  • PHP中错误与异常的日志记录用法分析

    PHP中错误与异常的日志记录用法分析

    这篇文章主要介绍了PHP中错误与异常的日志记录用法,较为详细的分析了php中错误与异常的区别以及日志记录的相应使用技巧,需要的朋友可以参考下
    2016-08-08
  • PHP中静态变量的使用方法实例分析

    PHP中静态变量的使用方法实例分析

    这篇文章主要介绍了PHP中静态变量的使用方法,结合实例形式分析了php静态变量的使用步骤与具体操作技巧,需要的朋友可以参考下
    2016-12-12
  • PHP简单实现断点续传下载的方法

    PHP简单实现断点续传下载的方法

    这篇文章主要介绍了PHP实现断点续传下载的方法,涉及php针对文件传输的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-09-09
  • 解决dede生成静态页和动态页转换的一些问题,及火车采集入库生成动态的办法

    解决dede生成静态页和动态页转换的一些问题,及火车采集入库生成动态的办法

    解决dede生成静态页和动态页转换的一些问题,及火车采集入库生成动态的办法...
    2007-03-03
  • php实现将HTML页面转换成word并且保存的方法

    php实现将HTML页面转换成word并且保存的方法

    这篇文章主要介绍了php实现将HTML页面转换成word并且保存的方法,结合实例形式分析了PHPWord工具的功能与使用方法,具有一定参考借鉴价值,需要的朋友可以参考下
    2016-10-10

最新评论