Service 类到底有啥意义?
共
1434字,需浏览
3分钟
·
2021-01-14 16:16
Java技术栈
www.javastack.cn
关注阅读更多优质文章
Service 类到底是什么含义?我相信如果碰到一个叫 SomethingService 的类,没法马上明白它到底起什么作用。
BD?实际是一个销售人员。Social Media 专家?可能是 3 周学会如何在 Instagram 上发布猫咪照片。软件工程师?实际上是堆砌代码的码农。工作头衔和工作角色有时候不挂钩,我们更喜欢把头衔弄得比角色更花哨。
Class 命名也是如此。另外,关注公众号Java技术栈,在后台回复:手册,可以获取一份最新的阿里 Java 开发手册,非常齐全。任何以 Service 为后缀的代码基本上都是一个逻辑垃圾箱。任何添加到程序中的新功能,最后总是以某种服务类的方式来实现。一个服务类需要大量的构造函数参数,使得测试起来非常麻烦。要测试一个新方法 GetUserCount()?可能需要 mock 7 个完全不相关的类来实例化这个服务类。如果 GetUserCount() 只依赖于服务类中的一个构造函数参数,那么最好把它移到自己的类中。这样一来,你就有一个非常简单的类,只有一个构造函数参数。当然,单独的 GetUserCount 类看起来不是那么酷,但至少你知道它到底是做什么的。你很可能见过类似 UserManager 这样的类,它管理用户。像服务类一样,它们也是逻辑垃圾箱。但是有一点区别。如果说服务类是一个普通的垃圾箱,那么 Manager 类就像一个纸板垃圾箱,它更特殊一点。你会面临和服务类一样的处理单元测试的问题。在做最微小的操作之前,你需要 mock 一大堆东西。很简单。给出与职责相匹配的合适名称。把一个类命名为GetUser,并且只有一个方法,这并不丢人。实现也简单,每个人都知道它是做什么的。容易进行单元测试。停止代码膨胀,简化这些类。比如,构建只有一个方法的类。另外,关注公众号Java技术栈,在后台回复:面试,可以获取我整理的 Java 系列面试题和答案,非常齐全。英文原文:https://medium.com/datadriveninvestor/the-true-meaning-of-service-and-manager-class-names-d09a08731fd9译文:https://m.sohu.com/a/440722848_268033/
浏览
73点赞
评论
收藏
分享
手机扫一扫分享
分享
举报
点赞
评论
收藏
分享
手机扫一扫分享
分享
举报