gpt4 book ai didi

java - Caffeine:无法向 AsyncLoadingCache 提供 CacheWriter

转载 作者:行者123 更新时间:2023-11-30 02:16:07 26 4
gpt4 key购买 nike

我正在尝试编写一个接受 CacheWriterAsyncLoadingCache,但我收到了 IllegalStateException

这是我的代码:

CacheWriter<String, UUID> cacheWriter = new CacheWriter<String, UUID>() {
@Override
public void write(String key, UUID value) {

}

@Override
public void delete(String key, UUID value, RemovalCause cause) {

}
};

AsyncLoadingCache<String, UUID> asyncCache = Caffeine.newBuilder()
.expireAfterWrite(60, TimeUnit.SECONDS)
.writer(cacheWriter)
.maximumSize(100L)
.buildAsync((String s) -> { /* <== line 41, exception occurs here */
return UUID.randomUUID();
});

我得到了这个痕迹

Exception in thread "main" java.lang.IllegalStateException at com.github.benmanes.caffeine.cache.Caffeine.requireState(Caffeine.java:174) at com.github.benmanes.caffeine.cache.Caffeine.buildAsync(Caffeine.java:854) at com.mycompany.caffeinetest.Main.main(Main.java:41)

如果我将缓存更改为 LoadingCache 或删除 .writer(cacheWriter) 代码将正常运行。我究竟做错了什么?看来我为这两个对象提供了正确的类型。

最佳答案

不幸的是,这两个功能不兼容。虽然文档说明了这一点,但我已经更新了异常以更好地传达这一点。在 Caffeine.writer 中,它指出,

This feature cannot be used in conjunction with {@link #weakKeys()} or {@link #buildAsync}.

CacheWriter 是一个用于条目突变的同步拦截器。例如,它可能用于将其作为辅助层逐出到磁盘缓存中,而 RemovalListener 是异步的,使用它会导致条目不存在于任一缓存中的竞争。该机制是使用 ConcurrentHashMap 的compute 方法来执行写入或删除,并调用该 block 内的CacheWriter。

AsyncLoadingCache 中,该值稍后在 CompletableFuture 成功时实现,或者在 null 或出现错误时自动删除。当哈希表中的条目被修改时,这个 future 可能正在发生。这意味着 CacheWriter 通常会在没有具体化值的情况下被调用,并且可能无法执行非常智能的操作。

从 API 的角度来看,不幸的是,伸缩构建器(使用类型系统来禁止不兼容的链)比使用运行时异常更令人困惑。抱歉没有澄清错误,现在应该已修复。

关于java - Caffeine:无法向 AsyncLoadingCache 提供 CacheWriter,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48356731/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com