当前位置: 首页 > news >正文

国外二手表网站上海网站建设 缔客

国外二手表网站,上海网站建设 缔客,wordpress屏蔽广告插件,青岛制作网站哪家公司好LFU算法原理在Java中示例实现集成Caffeine的W-TinyLFU策略缓存实战总结LFU与LRU稍有不同,LFU是根据数据被访问的频率来决定去留。尽管它考虑了数据的近期使用,但它不会区分数据的首次访问和后续访问,淘汰那些访问次数最少的数据。 这种缓存策略主要用来处理以下场景: 数据…

  • LFU算法原理
  • 在Java中示例实现
  • 集成Caffeine的W-TinyLFU策略缓存实战
  • 总结

LFU与LRU稍有不同,LFU是根据数据被访问的频率来决定去留。尽管它考虑了数据的近期使用,但它不会区分数据的首次访问和后续访问,淘汰那些访问次数最少的数据。

这种缓存策略主要用来处理以下场景:

  • 数据访问模式多样化:当系统的数据访问模式差异较大,有些数据访问频率很高,而有些数据访问频率很低时,LFU算法能够有效地根据访问频率来淘汰数据,保证频繁访问的数据能够留在缓存中。
  • 长时高频数据访问:对于某些数据,虽然它们不是最近被访问的,但是它们在过去的一段时间内被访问的次数很多,这种情况下,LFU算法能够保证这些数据不会被错误地淘汰。
  • 缓存空间原则:当缓存空间非常有限,需要精确控制哪些数据应该被保留时,LFU算法可以提供基于频率的淘汰策略,以确保最重要的数据被保留在缓存中。
  • 对于缓存数据更新频繁:LFU算法优先淘汰访问频率低的数据,因此它适合那些数据更新频繁的场景,可以确保最新的数据更容易被缓存保留。
  • 缓存时长较短:LFU算法适合那些对数据持久性要求不是特别高的场景,因为一旦数据被淘汰出缓存,就有可能丢失。

LFU算法原理

利用hash表和双向链表实现,并在hash表中存储了node节点后形成一个双向链表,这样既提高了查询效率也提高了操作效率。
内存淘汰原则:

  • 快速找到同一频率的节点,并同时淘汰掉最久未被使用过的数据;
  • 利用hash表存储每个频率相对应的节点信息;
  • 每个节点之间组成一个双向链表;

hash表中的key表示访问次数,value表示一个双向链表,链表中所有节点都是被访问过相同次数的数据节点。另外链表第三个元素freq被访问次数,这与hash表中的key值一样。当根据key找到其中一个节点时,进而知晓其访问次数和相关其它节点状态。
在这里插入图片描述
根据上图结构还缺少点什么,即如何根据key获取value。当然我们也可以通过hash表来存储key与节点之间的对应关系来查找。如下LFU算法的数据结构:
在这里插入图片描述

在Java中示例实现

创建链表缓存节点

package com.eyinfo.springlfu.lfu;import java.io.Serializable;public class LFUNode<K, V> implements Serializable {K key;V value;int frequency;public LFUNode(K key, V value) {this.key = key;this.value = value;this.frequency = 0;}
}

创建LFU缓存类(具体说明已在代码中标出)

package com.eyinfo.springlfu.lfu;import lombok.Getter;import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.Map;public class LFUCache<K, V> {private final int capacity;@Getterprivate Map<K, LFUNode<K, V>> cache;//用于跟踪每个键的频率private Map<K, Integer> frequencies;public LFUCache(int capacity) {this.capacity = capacity;//利用LinkedHashMap构建LFU缓存对象this.cache = new LinkedHashMap<K, LFUNode<K, V>>(capacity, 0.75f, true) {protected boolean removeEldestEntry(Map.Entry<K, LFUNode<K, V>> eldest) {return size() > LFUCache.this.capacity;}};this.frequencies = new HashMap<>();}public void put(K key, V value) {if (cache.containsKey(key)) {
http://www.yayakq.cn/news/814515/

相关文章:

  • oa官网下载北京网站seo收费标准
  • 百度搜索引擎的功能seo还能赚钱吗
  • 企业网站源码asp株洲seo网站优化
  • 建设银行网站建设情况辽宁鞍山网站建设
  • 百度做网站长沙seo步骤
  • 如何开发wap网站网页设计制作网站素材
  • 潍坊潍微贷是哪家网站建设的商务网站设计与开发
  • 公司制作网站需要什么知识wordpress写简历
  • 建设部官方网站做调查网站的问卷哪个给的钱高
  • 网站开发 无形资产网站应该如何进行优化
  • 网站优化与SEO区别南宁seo企业优化
  • 做网站和平台多少钱做网站需要代码吗
  • 城市建设理论研究官方网站做简约头像网站
  • 求职招聘网站排名前十名古网站典模板
  • 用层还是表格做网站快wordpress邮件客户端
  • 如何实现网站开发wordpress上传音乐文件
  • 精美的商城网站介绍衡水网站建设衡水
  • 梧州网站推广外包服务公司名称注册查询官网入口
  • 想建网站wordpress 手机客户端
  • 各国网站建设排名北京游戏网站建设
  • 广州市研发网站建设怎么样提供秦皇岛网站建设价格
  • 网站建设基本功能网站专题页面用什么做
  • 电子商务网站建设与管理a卷答案蓝潮网站建设
  • 地方门户类网站有哪些自媒体平台网站开发
  • 网站全屏图片怎么做免费个人简历模板下载免费
  • 网站开发常用软件网站建设销售工作好么
  • 成都企业网站建设及公司ppt网站制作 郑州
  • 宁夏建设工程造价站网站入返晋人员登记网页怎么制作
  • 如何搜索网站的内容深圳公司网站设计公
  • 建设机械官方网站网站是新媒体平台吗