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

如何运行后台线程定期清理列表中的某些元素?

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

如何运行后台线程定期清理列表中的某些元素?

你为什么要重新发明轮子?EhCache(以及任何适当的缓存实现)将为您完成此任务。也更轻巧

MapMaker

Cache
从Guava可以自动删除旧条目。

如果您 真的 想自己实现这一点,那就不是那么简单。

  1. 记住同步。您应该使用

    ConcurrentHashMap
    synchronized
    关键字来存储条目。这可能真的很棘手。

  2. 您必须以某种方式存储每个条目的上次访问时间。每次访问条目时,都必须更新该时间戳。

  3. 考虑驱逐政策。如果

    maxEntries
    您的缓存中有多个存储空间,则应先删除哪些存储空间?

  4. 您真的需要后台线程吗?

这令人惊讶,但是EhCache(企业级已经准备好并证明)没有使用后台线程来使旧条目无效。相反,它会等到映射已满并懒惰地删除条目。这看起来是一个不错的权衡,因为线程很昂贵。

  1. 如果您有后台线程,则每个缓存应该有一个线程还是全局线程?您是在创建新缓存时启动新线程还是拥有所有缓存的全局列表?这比您想象的要难…

回答完所有这些问题后,实现就非常简单:每秒大约遍历所有条目,如果满足您已经编写的条件,请删除该条目。



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

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

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