魔术笔反选_魔术二传手反图案

魔术笔反选

设置者和获取者是邪恶的。 创建JavaBean定义时,这似乎是个好主意。 但是它们对Java社区造成了很大的伤害。 通常不如null指针那么多,但足够了。

首先,许多初级人员相信实现setter和getter(嘿,在Eclispe中只需单击几下)确实可以正确封装。 我应该详细说明为什么不这样做吗?

另一件事是使用setter和getter反对YAGNI。 YAGNI代表您不需要它 。 这意味着您不应该开发该项目现在不需要的代码。 要强调的是这个词 。 许多程序员倾向于开发扩展实际功能并执行比实际需要更通用的代码。 即使从原则上讲它可能是有价值的:在大多数实际情况下却没有。 代码变得更加复杂,另一方面,项目从未发展到需要程序员创建泛化的阶段。

Setter和getter是YAGNI的一个干净,简单且使用非常广泛的示例。 如果setter除了设置字段的值外什么也不做,而getter除了返回字段的值外什么都不做,那为什么我们根本不需要它们呢? 为什么不将字段的访问修饰符更改为setter和getter的值(可能是public )?

答案通常是,您可能需要在getter或setter中实现一些更复杂的功能,然后不必更改bean提供的“接口”。 “ 您可能需要实施 ”一词表明这是YAGNI。 而且,这很危险。 实施setter和getter隐式公开了类的实现。 塞特犬做什么? 设置字段的值。 例如, setBirthDate()通过定义来设置字段birthDate 。 这就是编写调用setter的代码的用户会考虑的方式。 您可以在JavaDoc中记录setBirthDate()实际上“指定”了出生日期,但为时已晚。 您将方法命名为设置方法,仅此而已。 没有人阅读JavaDoc。 API规则。

以后,当您更改代码时, setBirthDate()不仅设置生日,甚至不设置生日,也不会通知用户。 更改是无声的,您只是更改了隐式提供给用户的界面。 会有bug,调试会话,新版本,这很好,因为这会创建工作场所(请讽刺,请)。 如果为用户提供对字段的直接访问,则将字段从public移到private访问修饰符的后面将导致编译时错误。 也许这只是一种怪异的个人喜好,但我更喜欢编译时错误而不是错误。 它们更易于修复(阅读:更便宜)。

不用担心:您仍然可以修改您的API。 您仍然可以从方法集中删除setter和getter,并迫使其他程序员修复其代码,这些代码隐含地假定setter确实已设置并且getter得到。 拜托

我写这篇文章的真实故事是什么?

从前,有一个物体可以做某事。 要执行其任务,您可以设置字段aaa或字段bbb ,但不能两者都设置。 该应用程序是通过这种方式开发的,并且已经超过六年了。 有一天,一位年轻的程序员公主骑着白马,希望使世界变得更美好。 他想使前面提到的类更安全,并修改了setter setAaa()以使字段bbb nullsetAaa() 。 单元测试大放异彩。 覆盖率为100%。 (我应该学会不撒谎。)他提交了图书馆的新书,几周后他完成了实习,回到学校。 那时应用程序开始使用该库的新版本。 由于这一微小的更改,他们惨遭失败,并回滚到了旧版本。 我们所有人都辛苦了,总而言之,由于简单的更改,公司花了大约一年的时间来工作,更不用说程序员从头顶拔下来的头发了。

为什么程序失败了? 有一些代码以如下方式克隆了包含字段aaabbb的对象:

BadBean newBadBean = new BadBean();newBadBean.setAaa(oldBadBean.getAaa());newBadBean.setBbb(oldBadBean.getBbb());

你明白了。 在新bean中,字段aaa始终为null

现在您已经阅读了本文,您将永远不会尝试创建一个聪明的二传手。 我知道你不会! 您知道的一句话是: 始终编​​码,就像最终维护您的代码的人是知道您的住所的暴力精神病患者。 看哪!

翻译自: https://www.javacodegeeks.com/2015/03/the-magic-setter-antipattern.html

魔术笔反选

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

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

相关文章

花5分钟了解C语言基本语法元素快来

点击上方蓝字关注我,了解更多咨询C语言是一种编程语言,和其它语言一样,也定义了自己的语法和词汇。学习C语言,首先要学习C语言的词汇,再学习C语言的语法规则,然后由词汇构成语句,由语句构成源程…

java8 策略模式_Java 8中的策略模式

java8 策略模式这是两个有关如何使用Java 8功能样式以及Cyclops模式匹配和Hamcrest库来实现策略模式设计的示例。 PrintDependingOnInput方法是一种策略,该策略将根据传递的日志对System.println一些消息。 AddPrefix是另一种策略,它将根据邮件内容向邮…

c语言中ftell函数是什么

点击上方蓝字关注我,了解更多咨询1、C语言函数ftell用于获取文件位置指针当前位置相对于文件首的偏移字节数。2、通过ftell函数获取当前文件的大小,然后通过fread函数读取缓冲区。返回值,如果成功,该函数返回位置标识符的当前值&a…

jdk入门_JDK 9 REPL:入门

jdk入门会议是聚会Java名人的好地方。 Devoxx France是与Java语言架构师,前同事和老朋友Brian Goetz( briangoetz )见面的一个机会。 我们谈论了JDK 9,而他全都热衷于REPL。 他提到,尽管Java SE 9中有很多重要功能 &am…

c语言中局部变量是什么

点击上方蓝字关注我,了解更多咨询1、函数内部定义的变量称为局部变量,其作用域仅限于函数内部,离开函数后无效,使用后报错。2、局部变量只能在函数内部使用,离开函数后无效,再次使用会报错。实例#include &…

java接口自动化Excel占位符_基于maven+java+TestNG+httpclient+poi+jsonpath+ExtentReport的接口自动化测试框架...

接口自动化框架项目说明本框架是一套基于mavenjavaTestNGhttpclientpoijsonpathExtentReport而设计的数据驱动接口自动化测试框架,TestNG 作为执行器,poi用于读取存放于excel的接口用例,jsonPath用于校验返回值,以及提取返回值。本…

本地构建和自动化构建_构建自动化面板

本地构建和自动化构建上周二,我作为持续讨论(#c9d9)的一部分,参加了一个关于Build Automation主题的在线讨论会,这是一系列有关敏捷,持续交付和DevOps的社区讨论会。 自动化构建流程面临许多挑战…

C语言为什么要定义short,int,long这么多整数类型?

点击上方蓝字关注我,了解更多咨询整数类型有int、short int、long int三种类型,用于需要不同存储空间的整数使用。整数类型有正整数和负整数之分,在C语言中,规定整型的最高位为符号位,最高位为“0”表示正数&#xff0…

java中逗号怎么加_Java中如何将字符串从右至左每三位加一逗号

/*** * 将字符串从右至左每三位加一逗号* ** param str 需要加逗号的字符串* return 以从右至左每隔3位加一逗号显示*/public static String displayWithComma(String str){str new StringBuffer(str).reverse().toString(); // 先将字符串颠倒顺序String str2 "";…

小度拆卸_拆卸invokedynamic

小度拆卸许多Java开发人员认为JDK的第七版有些令人失望。 从表面上看,仅少数语言和库扩展使它成为了发行版,即Project Coin和NIO2 。 但在幕后,该平台的第七个版本对JVM类型系统进行了最大的扩展,这是其最初发行后引入的。 添加in…

c语言中函数参数类型的探究

点击上方蓝字关注我,了解更多咨询函数中的参数个数可以是0,也可以是一个或多个参数。下面我们带着这三种不同的情况,分别在c语言中进行讨论。1、函数没有参数,表示没有参数列表。int func1(); //声明一个函数,该函数…

java rotate怎么用_jQuery旋转插件jqueryrotate用法详解

本文实例讲述了jQuery旋转插件jqueryrotate用法。分享给大家供大家参考,具体如下:CSS3 提供了多种变形效果,比如矩阵变形、位移、缩放、旋转和倾斜等等,让页面更加生动活泼有趣,不再一动不动。然后 IE10 以下版本的浏览…

c语言野指针产生的原因

点击上方蓝字关注我,了解更多咨询1、指针变量未初始化,任何指针变量刚被创建时不会自动成为 NULL 指针,它的缺省值是随机的。所以,指针变量在创建的同时应当被初始化,要么将指针设置为 NULL ,要么让它指向合…

java rhino_在Java 8中使用Rhino

java rhinoJava将Nashorn作为JSR 223的新JavaScript实现(javax.scripting)。 尽管这无疑是个好消息(通过直接生成Java代码,Nashorn比Rhino快得多),但它也带来了一些挑战: Nashorn与Rhino并非10…

docx 图片预处理 Java_如何在java中将docx文件头图像复制到另一个docx文件中

尝试(未经测试的):void attachHeader(HeaderPart sourcePart, WordprocessingMLPackage targetPkg) throws Docx4JException {HeaderPart newHeaderPart new HeaderPart();newHeaderPart.setContents(XmlUtils.deepCopy(sourcePart.getContents()));if (sourcePart.getRelatio…

c语言中assert函数的使用注意

点击上方蓝字关注我,了解更多咨询1、使用assert检查函数开始时传入参数的合法性。2、每个assert只检验一个条件,因为在同时检验多个条件时,如果断言失败,就无法直观地判断哪个条件失败。实例int resetBufferSize(int nNewSize) {/…

es 调整gc_实际中进行GC调整

es 调整gc调优垃圾回收与任何其他性能调优活动没有什么不同。 您需要确保您了解当前的情况和所需的结果,而不是因为对应用程序的随机部分进行调整而产生了诱惑。 通常,只需执行以下过程即可: 陈述您的绩效目标 运行测试 测量 与目标比较…

game connect4 java_为我的connect 4数学游戏创建一个积分系统

我试着在每次用户得到正确答案时加一分,如果在我的“连接4”数学游戏中答错了,我就拿走一分。在游戏中,用户把一个计数器放在想要的地方,问题就会弹出,等待答案,以便继续。这段代码中的所有内容都能正常工作…

内核中断处理流程_处理中断

内核中断处理流程我只是在观看Heinz Kabutz的VJUG采访 ,这启发了我写一篇有关中断的文章。 顺便说一句,我建议您订阅VJUG YouTube频道 -确实非常有用。 Heinz始终是物有所值的,很难不学习很多东西就很难观看他的演讲。 他提出了如何处理Inte…

c语言中assert函数是什么

点击上方蓝字关注我,了解更多咨询1、assert将通过检查表达式expresion的值来决定是否需要终止执行程序。2、如果表达式expresion的值是假的(即0),它将首先向标准错误流stderr打印错误信息。通过调用abort函数终止程序运行。否则,assert没有效…