课程咨询: 400-996-5531 / 投诉建议: 400-111-8989
认真做教育 专心促就业
我们在上文中给大家简单介绍了软件开发常见的缓存类型都有哪些,而本文就再给大家简单分享一下,缓存回收策略及回收方法都有哪些,希望通过对本文的阅读,大家对软件开发缓存应用有更多的了解。
一、缓存回收策略
缓存的回收策略总体上来说包含:基于空间的回收策略、基于容量(空间)的回收策略、基于时间的回收策略和基于对象引用的回收策略。
基于空间
基于空间指缓存设置了存储空间,如设置为10MB,当达到存储空间上限时,按照一定的策略移除数据。
基于容量
基于容量指缓存设置了大大小,当缓存的条目超过大大小时,按照一定的策略移除旧数据。
基于时间
TTL(TimeToLive):存活期,即缓存数据从创建开始直到到期的一个时间段(不管在这个时间段内有没有被访问,缓存数据都将过期)。
TTI(TimeToIdle):空闲期,即缓存数据多久没被访问后移除缓存的时间。
基于对象引用
软引用:如果一个对象是软引用,则当JVM堆内存不足时,垃圾回收器可以回收这些对象。软引用适合用来做缓存,从而当JVM堆内存不足时,可以回收这些对象腾出一些空间供强引用对象使用,从而避免OOM。
弱引用:当垃圾回收器回收内存时,如果发现弱引用,则将它立即回收。相对于软引用,弱引用有更短的生命周期。
注意:只有在没有其他强引用对象引用弱引用/软引用对象时,垃圾回收时才回收该引用。即如果有一个对象(不是弱引用/软引用对象)引用了弱引用/软引用对象,那么垃圾回收时不会回收该弱引用/软引用对象。
二、回收算法
使用基于空间和基于容量的缓存会使用一定的策略移除旧数据,通常包含:FIFO算法、LRU算法和LFU算法。
FIFO(FirstInFirstOut):先进先出算法,即先放入缓存的先被移除。
LRU(LeastRecentlyUsed):近少使用算法,时间时间距离现在久的那个被移除。
LFU(LeastFrequentlyUsed):不常用算法,一定时间段内使用次数(频率)少的那个被移除。
实际应用中基于LRU的缓存居多。
【免责声明】本文系本网编辑部分转载,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。如涉及作品内容、版权和其它问题,请在30日内与管理员联系,我们会予以更改或删除相关文章,以保证您的权益!更多内容请在707945861群中学习了解。