从头开始在 Java 中实现 LRU 缓存
从头开始在 Java 中实现最近最少使用 (LRU) 缓存对于以下人员来说是一项很有价值的练习:了解数据结构和并发性。虽然 EHCache 和 OSCache 之类的库简化了任务,但创建自己的库可以让您深入了解底层机制。
对于多线程环境,LinkedHashMap 成为强有力的竞争者,它提供恒定时间访问,同时保留插入顺序。然而,由于Java的标准LinkedHashMap不是线程安全的,所以常见的方法是使用Collections#synchronizedMap来包装它。
利用并发数据结构
而LinkedHashMap具有同步功能提供了可靠的解决方案,更新的并发数据结构提供了潜在的改进。通过扩展 ConcurrentHashMap 并复制 LinkedHashMap 使用的逻辑,您可以制作高度并发的 LRU 缓存。
但是,目前谨慎的做法是坚持使用经过验证的 LinkedHashMap 和 Collections#synchronizedMap 组合。如果需要,您还可以在将来探索扩展 ConcurrentHashMap 以增强并发性。
实现片段
以下是使用 LinkedHashMap 和同步的当前实现的要点:
<code class="java">private class LruCache<a b> extends LinkedHashMap</a><a b> { private final int maxEntries; public LruCache(final int maxEntries) { super(maxEntries + 1, 1.0f, true); this.maxEntries = maxEntries; } @Override protected boolean removeEldestEntry(final Map.Entry</a><a b> eldest) { return super.size() > maxEntries; } } Map<string string> example = Collections.synchronizedMap(new LruCache<string string>(CACHE_SIZE));</string></string></a></code>
以上是如何用Java实现线程安全的LRU缓存?的详细内容。更多信息请关注PHP中文网其他相关文章!

本文讨论了使用Maven和Gradle进行Java项目管理,构建自动化和依赖性解决方案,以比较其方法和优化策略。

本文使用Maven和Gradle之类的工具讨论了具有适当的版本控制和依赖关系管理的自定义Java库(JAR文件)的创建和使用。

本文讨论了使用咖啡因和Guava缓存在Java中实施多层缓存以提高应用程序性能。它涵盖设置,集成和绩效优势,以及配置和驱逐政策管理最佳PRA

本文讨论了使用JPA进行对象相关映射,并具有高级功能,例如缓存和懒惰加载。它涵盖了设置,实体映射和优化性能的最佳实践,同时突出潜在的陷阱。[159个字符]

Java的类上载涉及使用带有引导,扩展程序和应用程序类负载器的分层系统加载,链接和初始化类。父代授权模型确保首先加载核心类别,从而影响自定义类LOA


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

Atom编辑器mac版下载
最流行的的开源编辑器

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

禅工作室 13.0.1
功能强大的PHP集成开发环境

WebStorm Mac版
好用的JavaScript开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)