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

总结

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

相关文章

  • php中define用法实例

    php中define用法实例

    这篇文章主要介绍了php中define用法,实例分析了php使用define定义常量的使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-07-07
  • php实现xml与json之间的相互转换功能实例

    php实现xml与json之间的相互转换功能实例

    这篇文章主要介绍了php实现xml与json之间的相互转换功能,结合实例形式分析了php实现xml转json及json转xml的相关原理与实现技巧,具有一定参考借鉴价值
    2016-07-07
  • PHP JSON 数据解析代码

    PHP JSON 数据解析代码

    PHP解析JSON 数据代码,与大多数流行的 Web 服务如 twitter 、人人网通过开放 API 来提供数据一样,它总是能够知道如何解析 API 数据的各种传送格式,包括 JSON,XML 等等。
    2010-05-05
  • php7性能提升的原因详解

    php7性能提升的原因详解

    在本篇文章里小编给大家分享是的关于php7性能提升的原因以及相关知识点,有需要的朋友们参考下。
    2019-10-10
  • 基于ThinkPHP实现批量删除

    基于ThinkPHP实现批量删除

    这篇文章主要介绍了基于ThinkPHP实现批量删除的代码实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2015-12-12
  • redis+php实现微博(二)发布与关注功能详解

    redis+php实现微博(二)发布与关注功能详解

    这篇文章主要介绍了redis+php实现微博发布与关注功能,结合实例形式分析了php结合redis实现微博的发布及关注相关操作技巧,需要的朋友可以参考下
    2019-09-09
  • php中去除所有js,html,css代码

    php中去除所有js,html,css代码

    php中去除所有js,html,css代码,方便php的小偷采集程序的制作。
    2010-10-10
  • PHP swoole的process模块创建和使用子进程操作示例

    PHP swoole的process模块创建和使用子进程操作示例

    这篇文章主要介绍了PHP swoole的process模块创建和使用子进程操作,结合实例形式分析了swoole的进程管理process模块实现进程间通信相关操作技巧,需要的朋友可以参考下
    2020-03-03
  • php绘制一个扇形的方法

    php绘制一个扇形的方法

    这篇文章主要介绍了php绘制一个扇形的方法,涉及GD库中imagefilledarc方法的使用技巧,需要的朋友可以参考下
    2015-01-01
  • PHP安全防范技巧分享

    PHP安全防范技巧分享

    这里简单介绍一些基本编程要点, 相对系统安全来说,php安全防范更多要求编程人员对用户输入的各种参数能更细心.
    2011-11-11

最新评论