建设者还是二传手?

不用说,每个对象都需要先创建才能使用。 无论我们是在谈论域,框架,库还是任何其他类型的类,都没有关系。 当您的代码是面向对象的时,这些类仅是对象的定义。 在创建对象之前,不能使用它们。

在谈论对象的初始化时,我们经常需要考虑依赖关系。 您将如何注入它们? 您会使用构造函数还是二传手?

让我来帮助您做出正确的决定。

很久以前..

……需要处理一些事件。 为此,我们必须首先从存储库中检索必要的数据,然后将其传递给触发器,该触发器负责根据给定的数据触发适当的操作。

在实现过程中,我们创建了以下类:

public class SomeHandler {public SomeHandler(Repository repository, Trigger trigger) {// some code}public void handle(SomeEvent event) {// some code}
}

事情总是在变化。 我们的客户告诉我们,他们有时会需要存储从存储库中检索到的一些信息,然后才能采取适当的措施。 他们需要此数据用于统计目的和进一步分析。

更改后,这是我们班级的样子:

public class SomeHandler {public SomeHandler(Repository repository, Trigger trigger) {// some code}public SomeHandler(Repository repository, Trigger trigger, SnapshotTaker snapshotTaker) {// some code}public void handle(SomeEvent event) {// some code}
}

又过了一个月,客户提出了另一个要求。 他们希望有可能在触发事件后立即启用通知。 对于某些紧急事件,这对于他们来说是必要的。 他们希望具有更高的透明度。

好的,现在我们可以启用两件事:

public class SomeHandler {public SomeHandler(Repository repository, Trigger trigger) {// some code}public SomeHandler(Repository repository, Trigger trigger, SnapshotTaker snapshotTaker) {// some code}public SomeHandler(Repository repository, Trigger trigger, Notifier notifier) {// some code}public SomeHandler(Repository repository, Trigger trigger, SnapshotTaker snapshotTaker, Notifier notifier) {// some code}public void handle(SomeEvent event) {// some code}
}

代码看起来不错,不是吗? 好的,这是一个反问。 让我们做些事情。

构造器与否?

在上面的示例中,我们有四个构造函数的类。 为什么那么多? 由于客户需求的变化。 这很好。 一个应用程序应该满足客户的需求。

问题出在哪里? 问题在于类的设计。

为什么我们有这么多构造函数? 由于某些依赖项是可选的,因此它们的存在取决于外部条件。

我们需要这么多构造函数吗?

在回答这个问题之前,最好先问一个不同的问题: 构造函数的目的是什么?

我们应该创建一个处于有效状态的对象。 如果需要做更多的事情来使对象可用,我们就不应创建实例。 这就是为什么所有必需的依赖项都应放在构造函数中的原因

另一方面, 我们应仅将所需的依赖项放在构造函数中 。 构造函数不是放置任何可选内容的地方。 如果某些东西是可选的,则意味着我们不需要它来创建有效的对象。

如果我们想使用其他很好的依赖项,则应该以其他方式注入它们。 这就是二传手的角色。 我们没有被迫调用setter方法。 我们可能有需要,但这不是必需的。 当依赖项为选项时,应使用setter

那么,我们需要那么多构造函数吗? 让代码作为答案:

public class SomeHandler {public SomeHandler(Repository repository, Trigger trigger) {// some code}public void setSnapshotTaker(SnapshotTaker snapshotTaker) {// some code}public void setNotifier(Notifier notifier) {// some code}public void handle(SomeEvent event) {// some code}
}

更少的代码,更具描述性。 从第一刻起,您就知道需要什么以及可以使用什么。

塞特犬?

我不喜欢二传手。 为什么? 因为这些方法以某种方式破坏了封装 。

但是,我们可以用什么代替二传手? 在给定的示例中可以代替使用什么?

好吧,我们不会避免使用这些方法。 或更确切地说,我们需要它们的功能。 需要让客户启用该功能。 在给定的示例中,因为需要变量,所以需要保留它们。 但是,我们总是可以使代码更好。 与域更多相关。 怎么样? 我们只需要显示与域的这种关系:

public class SomeHandler {public SomeHandler(Repository repository, Trigger trigger) {// some code}public void enable(SnapshotTaker snapshotTaker) {// some code}public void enable(Notifier notifier) {// some code}public void handle(SomeEvent event) {// some code}
}

我写道,我不喜欢setter,因为它们的中断封装,但这不仅与方法的功能本身有关。 使用诸如setX之类的方法的另一个问题是,即使它们的名称也是面向实现的。 有时,setter功能是必需的。 但是,请记住以一种显示域含义的方式来命名方法。

太多选择

有时,太多的选择也会带来问题。 这可能表明您违反了“ 单一责任原则” 。

如果选择太多,可能意味着责任过多,值得重新考虑当前的解决方案。

每当在类的代码中添加另一个可选部分时,都要非常小心。 也许这堂课做得太多了?

字尾

希望您觉得这篇文章有用。

现在,您应该知道应该只在构造函数中放置必需的依赖项。 任何可选的依赖项都需要其他命名良好的方法。

下一步是什么?

我们去创建一些对象:)

翻译自: https://www.javacodegeeks.com/2016/02/constructor-or-setter.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/354647.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SSH连接远程服务器,本地known_hosts文件记录了什么

今天工作时,使用ssh命令远程连接公司的本地服务器时,突然出现以下错误bash-3.2$ ssh argus192.168.200.8 WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED! IT IS POSSIBLE THAT SOMEONE IS DOING SOMETHING NASTY! Someone could be eavesdroppin…

“全人类的知识宝藏”维基百科迎来了20岁的生日!

维基百科从一个伟大的想法开始,与无数的像你像我一样的阅读者,创作者,捐赠者和粉丝经历了互联网的20年,今天让我们一起为这个属于所有互联网人的成果庆祝一次生日。值此20周年特地为它做了一个主页:https://wikimediaf…

转:智能音箱市场深度报告:怎么大家都在抢这个两亿小蛋糕?

原文链接:http://www.sohu.com/a/199335366_115978 智能音箱是今年最热的智能硬件项目之一。目前,智能音箱已经有了比较成熟的技术方案和模式思路,但消费市场似乎依然秉持着比较谨慎的态度。智能音箱市场上的主流产品都有什么思路&#xff1f…

Tailwindcss尤大神都fork了,是未来的趋势?

最近Tailwindcss频繁出现在我的视野里,从单词拼写中看,多多少少与css有点关系。近几年是JS框架大行其道,CSS方面少有新的框架出现。昨天突然看到尤大神在Github上的动态,fork了该项目,看来马上要火的节奏啊&#xff01…

JUnit 5 –架构

现在我们知道如何设置JUnit 5并使用它编写一些测试 ,下面让我们看一下。 在本文中,我们将讨论JUnit 5架构以及采用这种方式的原因。 总览 这篇文章是有关JUnit 5的系列文章的一部分: 设定 基本 建筑 条件 注射 … JUnit 4 忽略Hamcre…

前端程序员书桌上不可缺少的CSS书籍

作为前端,CSS不仅要会,而且要精通,随着各种浏览器规范参差不齐和网页交互多元化的趋势越来越复杂,前端程序员必须要将CSS基础知识打牢。由于现在的框架越来越多,导致很大一部分程序员的工作只是拿着现成的组件布局&…

nodejs 进阶:图片缩小

demo 效果: 代码: /*** Created by ZXW on 2017/10/30.*/ var fs require(fs); var gm require(gm);gm(./不饿.jpg).resize(50, 50,"!").write(./不饿1.jpg, function (err) {if (!err) console.log(done);});2017-10-30 22:10:46转载于:ht…

可能是最先出来的关于介绍使用Vue3的一本书

Vue3 release版本已发布有几个月了,不少公司都已经开始使用vue3开发项目了,市场上的主流的框架如:Vant,Element UI,Taro也都发布了支持Vue3的版本。Vue3很多的开发优势自不必再说,学习上手vue3已经成为每个…

JPA陷阱/错误

根据我在帮助团队和进行培训方面的经验,这是我遇到的一些陷阱/错误,这些陷阱/错误在使用JPA的基于Java的系统中引起了一些问题。 需要一个公共的无参数构造函数 始终使用双向关联/关系 使用OneToMany收集可能庞大的集合 需要一个公共的无参数构造函数…

CSGL

glShadeModel void glShadeModel(GLenum mode) GL_FLAT/【GL_SMOOTH】 着色技术选择 glClearDepth GL.glClearDepth(depth); glClearDepth:设置深度缓存的清除值 参数 depth 指定清除深度缓存时使用的深度值。 说明 本函数指定用glClear清除深度缓存时所使用的深度值…

强大的Canvas开源库Fabric.js简介与开发指南

什么是Fabric.js?Fabric.js 是一个强大且简单的Javascript HTML5 Canvas库。官网地址:http://fabricjs.com/为什么要使用Fabric.js?Canvas提供一个好的画布能力, 但是Api不够友好。绘制简单图形其实还可以, 不过做一些复杂的图形绘制, 编写一…

模拟qq斗地主-准备发牌抢地主都是农民下一轮准备

为什么要搞这样一个项目?? 1,满足自己的java网络多线程编程的欲望!因为之前一直都是搞web开发,服务器和客户端数据交流人家web服务器早就给你搞好了,比如tomcat,jetty...等等,其实之前脑子里就有…

rube3xxx_Rube GoldbergSpring整合

rube3xxxSpring Integration为集成系统所涉及的一些复杂性提供了非常好的抽象-Spring Integration从Integration的角度完美地满足了Facade的定义-简化了对复杂基础系统的访问。 为了说明这一点,请考虑一个简单的系统,该系统仅接收一条消息,然…

纯CSS实现React Logo图形,内含详细解析

以上是将要实现的效果&#xff0c;Javascript框架React的Logo图形&#xff0c;首先我们来拆解下&#xff0c;它包括三个交叉的椭圆和中间一个圆点&#xff0c;所以我们Html元素可以用以下代码实现&#xff1a;<div class"main"><div class"ellipse ell…

学生ID查询

var http require("http");var server http.createServer(function(req,res){//得到urlvar userurl req.url;res.writeHead(200,{"Content-Type":"text/html;charsetUTF8"})//substr函数来判断此时的开头if(userurl.substr(0,9) "/stud…

平等还是认同?

将对象存储在集合中时&#xff0c;同一对象永远不能添加两次非常重要。 这是集合的核心定义。 在Java中&#xff0c;使用两种方法来确定两个引用的对象是否相同或它们是否可以同时存在于同一Set中。 equals&#xff08;&#xff09;和hashCode&#xff08;&#xff09;。 在本文…

二次优化大招(由泰勒公式推出最值条件)

经过前两篇的铺垫&#xff0c;这一篇迎来了高潮。先说一句&#xff1a;特征值大法好&#xff01; 在开始正文之前&#xff0c;先看以下简单的推导 有了这些&#xff0c;理解下面的泰勒公式推出最值条件就容易了 转载于:https://www.cnblogs.com/Mr-ZeroW/p/7764916.html

前端自动化测试浅析

前言&#xff1a;测试简介前端常见的问题&#xff1a;修改某个模块功能时&#xff0c;其它模块也受影响&#xff0c;很难快速定位bug多人开发代码越来越难以维护不方便迭代&#xff0c;代码无法重构代码质量差增加自动化测试后&#xff1a;我们为核心功能编写测试后可以保障项目…

使用SpringData出现java.lang.AbstractMethodError

最近学习一下SpringData&#xff0c;在添加SpringData支持的时候&#xff0c;出现了这样的问题&#xff1a; SpringData需要的jar有:spring-data-jpa.jar spring-data-commons.jar slf4j-api.jar 没有添加slf4j也会出现一个异常&#xff0c;不过那个异常说的非常明确&#xf…

2021这份电子书单请收好(品类齐全)!

2021年已经快过去一个月了&#xff0c;今年的读书计划有没有安排上&#xff0c;这里有份长长的书单&#xff0c;多年的积累&#xff0c;品类齐全&#xff0c;赶快从中挑几本加入今年的读书计划里。•《货币战争2&#xff1a;金权天下》 - 宋鸿兵.mobi•《圣经》中英对照豪华版 …