service和serviceImpl的选择

同行中,有些同行公司的代码风格是service层=service接口+serviceImpl实现类;
而有的同行公司的代码风格是service层=service类;

为什么不一样呢?
以前没想过这个问题,今天突然对这个产生了疑惑,通过百度,和github及朋友处以及自己的思考,有了如下结论:
当项目的业务逻辑简单时,可选择service层=service类;
当项目的业务复杂时,可选择service层=service接口+serviceImpl实现类;
至于复杂和简单的度得自己把握;

为什么有这样的区别呢?
我举个例子,
当我在定义接口时,会有一个权限验证的方法,
但是并不是所有的请求都回进入这个方法(比如登录接口);
此时,可将请求经过的路线分为两类:1(进入过权限验证),2(没有进入过权限验证);

但这两条路都是从同一个端口进入后台的。

类比
service层=service接口+serviceImpl实现类;
service接口层就是端口,serviceImpl实现类里不同的方法就是路1,和路2.乃至路3。
以上为举例。

当使用
service层=service接口+serviceImpl实现类——的形式后,
业务逻辑将会更便于扩展。
但缺点就是:多了一层——service接口;

凡事都有得必有失;
但我们可以因地制宜,选择最合适自己项目的。

补充

看 spring实战(第4版)的时候,看到另一种解释

如下:

spring鼓励应用程序的各个层以接口的形式暴露功能,在service层,可以使用service接口+serviceImple实现类,也可以使用service类,但考虑到“接口时实现松耦合的关键”,所以更加推荐使用

service接口+serviceImple实现类的方式来写service层代码。

核心是“松耦合”

相关文章:

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 2.1 Activity 2.1.1 Activity的生命周期全面分析 典型情况下的生命周期:在用户参与的情况下...
    AndroidMaster阅读 8,296评论 0 8
  • 传统的三层架构 传统的web开发都有典型的三层结构,从上到下依次是controller,service,dao。c...
    仝键阅读 7,615评论 1 6
  • 0.Android手机操作系统的四层架构? Applications , Application Framewor...
    lucas777阅读 12,417评论 0 16
  • iOS网络架构讨论梳理整理中。。。 其实如果没有APIManager这一层是没法使用delegate的,毕竟多个单...
    yhtang阅读 10,691评论 1 23
  • 本卦阐述了在发展过程中如何冲破阻碍,为下一步的行动积聚力量的种种原则。
    子鱼_cd6d阅读 1,193评论 0 0

友情链接更多精彩内容