业务场景:
业务中会涉及到不同科目报表查询的操作,不同表操作大致的流程类似都是 先查询数据库 ,有数据直接返回,没有数据会初始化数据,再查询一遍结果返回,操作中不同的只是各个科目的数据源和类型不同,这就很适合模板方法设计模式。
talk is cheap,just show the code
接口类定义查询接口
public interface BbSerivce {
/**
* 查询
* @param id
* @return
*/
Object query(Long id);
}
抽象类阉割版大致如下
public abstract class AbstractBbServiceImpl implements BbService {
@Override
public Object query(Long id) {
if (checkParam(id)) {
throw new SysException(MessageEnums.PARAM_ERROR);
}
List<?> list = getReport(id);//获取数据
if (CollectionUtils.isEmpty(list)) {
initReport(id); //初始化数据
list = getReport(id);
}
return list;
}
/**
* 获取模板
*
* @param id
* @return
*/
public abstract List<?> getReport(Long id);
/**
* 初始化数据
*
* @param templates
* @param id
*/
public abstract void initReport(Long id);
}
子类就只用重写获取模板的方法和初始化数据的方法就好了
@Service
public class B1ServiceImpl extends AbstractBbServiceImpl {
@Override
public void initReport(Long id) {
//业务处理
}
@Override
public List<?> getReport(Long id) {
////业务处理
}
}
@Service
public class B2ServiceImpl extends AbstractBbServiceImpl {
@Override
public void initReport(Long id) {
//业务处理
}
@Override
public List<?> getReport(Long id) {
////业务处理
}
}
看起来跟简单哈!接下来希望在实际开发中用到更多设计模式