- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
Javadoc说:
Returns a view of the entries stored in this cache as a thread-safe map. Modifications made to the map directly affect the cache.
我缺少的是有关 View 访问是否会影响准入和驱逐政策的信息。根据this old related issue它没有:
In Guava's CacheBuilder we added the asMap() view specifically to allow bypassing the cache management routines. There a cache.asMap().get(key) is a peek operation.
这确实有道理。 OTOH 该 View 提供了许多无法直接操作的操作,用户可能会想使用它们,希望它们像直接操作一样更新访问统计信息。
例如,我发现自己使用cache.asMap().putIfAbsent
,因为我的值是键的函数,因此替换它们是没有意义的。我希望它能够像 cache.put
一样工作,以防条目不存在。
最佳答案
这是 Guava 的 Map.get
最初讨论的一部分,但很可能是一个糟糕的主意,沟通不畅,最终失败了。一个合理的原因是,用户没有预料到大多数 Map
操作会产生副作用,而 MapMaker
会随着 map 的计算而改变,从而破坏了 equals
方法。
回想起来,将任何 Map
方法视为不同的方法都违反了最小惊讶原则,并且不是很有用。这很可能是在实现过程中实现的,但由于团队脱节和大量细节,我忘记了这一点。我们还决定了这样的原则:用户不需要知道策略如何工作,也不需要通过配置旋钮来影响其实现,而安静的 get
会暴露这些。
然而,无论好坏,一个方面确实存在。与Cache.getIfPresent
不同,Map.get
不会记录命中率统计信息。同样,对于所有其他 Map
操作,它们可能会选择不更新 CacheStats
。在 Guava 中,这被表述为,
No stats are modified by operations invoked on the asMap view of the cache.
这在 Caffeine 中针对其他 Java 8 方法进行了稍微修改,
No stats are modified by non-computing operations invoked on the
asMap view of the cache.
这种选择退出统计数据的行为本不应该发生,但这是最初讨论的残余。这是一个微妙的细节,可能不会被完全尊重,因为我相信 Guava 添加的计算 Map
方法没有这样做。值得庆幸的是,这是一个足够小的细节,没有引起很多问题,如果认为值得的话可以进行更改。
关于java - Caffeine Cache.asMap View 的行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48139062/
我使用身份验证 API 获取 token 并使用其他服务。此 API 返回 token 和过期时间。有可能获得它返回的过期时间并用这些值设置 expire_after_write 吗?目前此属性在 a
我使用的是 Caffeine v2.8.5,我想创建一个基于以下内容的可变到期缓存: 值(value)的创造/更新 最后一次访问(读取)此值。 无论先发生什么都应该触发该条目的删除。 缓存将成为三层值
我正在尝试使用 Caffeine 创建一个简单的(非加载)缓存。 Cache countsCache = CacheBuilder.newBuilder().build(); 编译失败,并
我使用的是 Caffeine v2.8.5,我想创建一个基于以下内容的可变到期缓存: 值(value)的创造/更新 最后一次访问(读取)此值。 无论先发生什么都应该触发该条目的删除。 缓存将成为三层值
引言 前面我们有学习Caffeine 《本地缓存性能之王Caffeine》,并且也提到SpringBoot默认使用的本地缓存也是Caffeine啦,今天我们来看看Caffeine如何与
1.概述 转载:真正的缓存之王,Google Guava 只是弟弟 Guava Cache,他的优点是封装了get,put操作;提供线程安全的缓存操作;提供过期策略;提供回收策略;缓存监控。当缓存的数
我在我的项目 ( https://github.com/blemale/scaffeine ) 中使用了 Scaffeine,它是 Caffeine ( https://github.com/ben-
当我单独运行它们时,我为 Caffeine CacheLoader 实现编写的单元测试(JUnit、Mockito)全部成功,但当我一起运行它们时,其中一个测试失败了。我相信我在所有测试对象设置中都遵
我希望添加几个不同的 LoadingCache到 Spring CacheManager ,但是我不明白如何使用 CaffeineCacheManager 实现这一点。看来只有一个加载器可以刷新内容,
我正在尝试使用缓存来根据请求类型维护可路由服务器的列表。 LoadingCache serversByRequestType = Caffeine.newBuilder() .writer(new
我想在缓存数据或逐出数据后获取自定义缓存中条目的详细信息。 我尝试使用执行器依赖项来获取“执行器/指标”路径以获取详细信息,但我得到了空的 tomcat 服务器缓存。没有任何迹象表明我的自定义缓存为
我想使用咖啡因进行缓存,并且需要有一个后写功能。我想限制写入数据库的次数。 documentation谈到回写缓存,所以它应该是可能的,但没有关于如何配置它的示例。我已经实现了一个 CacheWrit
Javadoc说: Returns a view of the entries stored in this cache as a thread-safe map. Modifications mad
我正在尝试编写一个接受 CacheWriter 的 AsyncLoadingCache,但我收到了 IllegalStateException。 这是我的代码: CacheWriter cacheWr
spring boot中集成了spring cache,并有多种缓存方式的实现,如:redis、caffeine、jcache、ehcache等等。但如果只用一种缓存,要么会有较大的网络消耗(如re
我使用 Web 和缓存依赖项创建 Spring Boot 2.0 Starter 项目: org.springframework.boot spring-b
我需要在不同的时间间隔检查一些端点,所以我设置了 Caffeine 的缓存构建器。 this.localeWeatherCache = newBuilder().build(); this.cur
我需要在不同的时间间隔检查一些端点,所以我设置了 Caffeine 的缓存构建器。 this.localeWeatherCache = newBuilder().build(); this.cur
我尝试使用咖啡因缓存并遇到问题: 假设缓存为空,我查询一个值,它使用加载程序并将新值加载到缓存中,2天后我查询相同的值,并得到旧值首先,然后在单独的线程上启动刷新,如果可以加载,则加载新值。 Caff
这里是 Java 8。有什么办法可以用Caffeine缓存框架(或任何其他与此相关的 JSR-107 兼容框架)在记录被逐出缓存时收到通知? 也许是某种EvictionEventListener之类的
我是一名优秀的程序员,十分优秀!