我遇到的问题是我的番石榴缓存未到期。我将我的代码留在下面。缓存只会在我再次写入缓存时到期。但是我从javadocs中获得的关于定时到期的内容是它应该在写完后到期x timeunit。任何帮助将不胜感激。
private static final Cache<UUID, RainbowWrapper> RAINBOWS = CacheBuilder.newBuilder()
.removalListener(new RemovalListener<UUID, RainbowWrapper>() {
@Override
public void onRemoval(RemovalNotification<UUID, RainbowWrapper> notification) {
CoreAPI.debug("Removing rainbow: " + notification.getKey().toString());
RainbowWrapper wrapper = notification.getValue();
for (UUID uuid : wrapper.getUuids()) {
CoreAPI.debug("Removing entity: " + uuid);
Bukkit.getWorlds().get(0).getEntitiesByClasses(Item.class, ArmorStand.class).stream()
.filter(entity -> entity.getUniqueId().equals(uuid))
.forEach(org.bukkit.entity.Entity::remove);
}
}
}).expireAfterWrite(FADE_TIME, TimeUnit.SECONDS).build();
答案 0 :(得分:8)
基本上,只要你不调用缓存的任何方法,就什么都不会发生,因为没有为缓存创建一个自己的线程是不可能的,这通常是不希望的,因此不是由番石榴自动完成的高速缓存中。
如果您只对缓存进行读取访问,则可能还需要一段时间才能调用您的删除侦听器,因为Guava假定对缓存的读取访问速度很快,因此尝试尽可能少地执行工作对于读访问,这意味着它通常不会调用删除侦听器。只有在一段时间内没有写访问时,缓存才会在读访问时进行清理和调用删除侦听器。
请注意,这仍然意味着过期功能正在运行:不会从任何缓存方法返回过期的条目。可能只会发生删除侦听器的调用时间比您预期的要晚。
如果您想强制及时删除通知,请定期致电Cache.cleanUp()
(例如,从单独的主题中)。
如果您在时间过后尽快收到通知很重要,我只需使用ScheduledExecutorService
并向其提交任务,而不是依赖缓存及其删除通知。