c# 本地完整缓存组件

用了一段时间java,java实现服务端程序很简单,有很多公共开源的组件或者软件。但是c#的很少。

  现在准备自己写点东西,学习下新的东西,总结下c#的内容以及我们经常用的内容,抽离成类,组件,模型。方便在开发时能够有个方向和参考。同时也方便设计,充分运用拿来主义,实现功能组合。

    本篇是前面几篇之后的续篇。前已经提到了关于缓存的例子。最简单的一种,就是开辟一个集合,放置数据,提供添加和获取的接口。我喜欢用stack和时间来计算平衡,这种应用是最简单的。后面一篇整理了网上的代码LRU实现的缓存,还是可以在很多场景下用的,每一个添加都操作,再最大值移除时很方便。

  最近在网上找了很久,都没有发现c#实现的本地缓存的组件但是java有很多。所以花了几天时间,自己做了一个K-V缓存,可以用,也可以修改,毕竟一个人的能力是有限的,java的很多本地缓存都是公司开发出来的。我提供了一个缓存的接口,一个排序比较接口以及创建缓存的工厂。

简单列举下,代码中有相信注释。

1.CacheConfig 缓存配置类,配置缓存时间,大小,移除策略等

2.ICache 缓存接口

3. JYCache 缓存实现类

4.CacheFactory 缓存创建类

5.IPolicyCompare 缓存比较器,用于策略消失时比较排序,选择要消失的缓存

策略:FIFO,LRU,LFU代码中已经实现。

这里有一个优化,就是LRU,如果允许使用很多内存空间,则在操作时会记录操作的先后顺序,类似网上的LRU实现。

如果不允许,则在触发消失时会去按照比较器排序,然后移除,这样有一个比较的过程,会慢。

关于比较器,这个我考虑了很久,原本是想让外部能够自定义。所以我抽取了一个接口,外部实现了以后就按照比较器消失。但是完成以后发现还是要改代码,因为在缓存的包装器中,我只是记录了缓存写入时间,服务时间以及服务次数,是按照FIFO,LRU,LFU策略来实现的。自定义的话我不知道要记录哪些操作,所以如果你需要,需要自己增加记录,在缓存实现的添加和获取2个方法中增加。然后实现比较接口。我已经在对外的实体中增加了一个custom字段用于扩展比较策略。

项目地址:

https://github.com/jinyuttt/JYCache.git

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值