栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

谷歌番石榴缓存invalidateAll()和cleanUp()之间的区别

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

谷歌番石榴缓存invalidateAll()和cleanUp()之间的区别

*此链接的 *第一部分
:Guava如何使CacheBuilder中的条目到期?

我将重点讨论 expireAfterAccess ,但是 expireAfterWrite 的过程几乎相同。从机制 上讲
,当您在CacheBuilder中指定 expireAfterAccess
时,缓存的每个段都会维护一个条目的链接列表访问队列,其顺序为从最近访问到最新访问。缓存条目实际上本身就是链接列表中的节点,因此,在访问条目时,它会将其从访问队列中的旧位置删除,然后移至队列的末尾。

第二部分 :通过此链接:Guava CacheLoader-如果同时设置了expireAfterWrite和expireAfterAccess,则invalidate不会立即使条目无效

invalidate
应该立即删除该条目-不等待其他查询-并且应强制在该键的下一个查询中重新加载该值。

cleanUp
:执行缓存所需的所有暂挂维护操作。确切地执行哪些活动(如果有)取决于实现。

github文档中获取 :https
:
//github.com/google/guava/wiki/CachesExplained

明确删除

在任何时候,您都可以显式使缓存条目无效,而不必等待条目被逐出。可以这样做:

individually, using Cache.invalidate(key)in bulk, using Cache.invalidateAll(keys)to all entries, using Cache.invalidateAll()

什么时候进行清理?

使用CacheBuilder构建的缓存不会“自动”执行清理和逐出值,也不会在值过期后立即执行清理或逐出值,或类似的任何操作。取而代之的是,如果写操作很少,它会在写操作期间或偶尔的读操作期间执行少量维护。

原因如下:如果我们要连续执行Cache维护,则需要创建一个线程,并且该线程的操作将与用户操作争夺共享锁。此外,某些环境限制了线程的创建,这会使CacheBuilder在该环境中无法使用。

相反,我们会将选择权交给您。如果您的缓存是高吞吐量的,那么您不必担心执行缓存维护以清理过期的条目等。如果您的缓存确实很少写入,并且您不想清理来阻止缓存读取,则您可能希望创建自己的维护线程,该线程定期调用Cache.cleanUp()。

如果要为很少有写入的缓存安排定期的缓存维护,只需使用ScheduledExecutorService安排维护。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/428575.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号