写这个博客主要是为了工作学习经验的记录笔记。
最近负责公司的分布式缓存设计开发,刚好用到设计模式,模板方法,代码有所简化,与实际项目代码细节不一样但是思想一样。
下面的CacheAbleDAO就应用到了模板方法search,负责处理数据库取数据还是缓存取存数据的部分逻辑,doSearch方法由各个业务DAO的子类实现自己的查询,Criteria接口主要是封装查询条件和cache相关参数比如cache key,isCacheable是否能够cache。具体代码如下
public abstract class CacheAbleDAO<E> { private Cache cache; public abstract List<E>doSearch(Criteria criteria); public final List<E>search(Criteria criteria){ List<E> result=null; //to determined whether the result have ability to put cache,if not, then go to DB directly if(!criteria.isCacheAble()) result=doSearch(criteria); else{ //to retrieve data from cache result=getFromCache(criteria); //to determined whether data is existed in distributed Cache, if not,then retrieve data from DB and store to distributed Cache if(result==null){ result=searchAndCache(criteria); } } return result; } private List<E> searchAndCache(Criteria criteria){ //firstly,to retrieve data set from DB List<E> result =doSearch(criteria); //secondly, put the data to distributed cache if(criteria.isCacheAble()) this.doCache(criteria,result); //finally, return data return result; } private void doCache(Criteria criteria,List result){ cache.put(criteria.getRegion(),criteria.getKey(),result); } private List<E> getFromCache(Criteria criteria){ return (List<E>)cache.get(criteria.getRegion(), criteria.getKey()); } }
业务子类DAO如下,其中数据库查询省略,
扫描二维码关注公众号,回复:
673864 查看本文章
public class XXXXXDAO<E> extends CacheAbleDAO<E>{ @Override public List<E> doSearch(Criteria criteria) { // do some DB query return null; } }
总结,为了不占用子类的继承extend,其实更好的方法是可以将模板方法改造为回调的方式,具体实现可以参看HibernateCallBack相关类源码实现.