1.应用场景
在JavaEE项目中 我们通常会将项目分层开发 在不同的层级中 通常使得servlet层调用service层 service层调用dao层
2.面向接口编程
在JavaEE项目中 我们通常会将dao层和service层设计为面向接口编程
面向接口编程的好处在于:
- 降低service层和dao层实现类/servlet层和service层实现类之间的耦合性 即当我们需要切换dao层/service层的实现方案时 仅仅需要改变实现类代码 而并不需要修改主调层级的代码
- 明确了service层/dao层的角色 并降低了servlet层/service层的维护成本 service只关心业务操作(包含多个数据库交互操作) 而不关心数据库交互 摆正了service层业务层的角色 并且当dao层实现类需要切换方案时 仅仅需要修改实现类的有关代码 而不需要改变service层的代码 大大降低了service层的维护成本 同理servlet层也是如此解释
3.servlet/service依然存在的耦合性问题
如果我们dao层/service层切换方案的形式是重写类的话 那么耦合性很低 但是如果我们切换方案的形式是通过增加类来实现的话 那么主调层级和实现类之间耦合性依旧很高 因此的话 我们通常会设计一个工厂类来生产这些所需的实现类 这样就可以降低主调层级和实现类之间的耦合性 将耦合性问题转移到了工厂和实现类之间
现在 我们需要想办法降低工厂类和实现类之间的耦合性 我们可以将实现类抽取到配置文件中 这样就可以实现我们的目标