CleanCode系列:不要"查找" 而是 直接 "要"

视频来源:不要查找需要的东西

概述:

    不要问中间人查找或者索要需要的东西,而是直接要需要的东西(迪米特原则)

启发:

    高质量的可测试的code来自创建过程和业务逻辑的分离。

将对象的创建过程和 业务逻辑分开有利于写出干净的代码:业务主逻辑清晰,而不是一堆新对象的创建过程和if else逻辑混合在一起。

  1. 我们可以使用建造者模式:factory,builder,provider等将对象的创建过程和业务逻辑分离开。

  2. 使用DI 依赖注入的方式向需要测试的模块注入直接依赖,这样在测试的时候就可以mock数据,也同时直接聚焦在主逻辑上写出可读性很好的代码,提高代码质量。

注意:在对象的初始化的时候尽量不要Null check,因为这会增加创建对象的困难,因为有时候确实需要传入Null参数,或者dummy来进行测试,如果参数不能为Null就意味着不许创建这个对象,而这些参数对象可能对于本次测试来说并没有意义,但是却因为Null check导致不能构造测试,这样会很让人痛苦。

依赖注入时的生命周期问题:

构造函数创建方式依赖注入:通常注入的参数对象的生命周期等于或者大于被注入方,这样不会内存泄露——因为被注入方被销毁的时候对于 注入的参数生命周期没有影响,注入的参数对象被销毁的时候,被注入方可能早就已经销毁了

方法参数类型注入:在运行时注入,通常注入的对象的生命周期比被注入方法所属对象生命周期短,这样方法运行完毕,参数对象可以被及时的垃圾回收,而不是长期被持有,导致长期占用内存。

反模式(通过中间人来查找信息):

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

相关阅读更多精彩内容

  • 1、springmvc用到的注解,作用是什么,原理。 @Controller注解 是在Spring的org.spr...
    小王学java阅读 3,938评论 0 1
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 33,184评论 18 399
  • 1. 面向对象特征 抽象:抽象是将一类对象的共同特征总结出来构造类的过程,包括数据抽象和行为抽象两方面。抽象只关注...
    十六郎阅读 1,657评论 0 1
  • 转:http://www.cnblogs.com/java1024/ 各大公司Java后端开发面试题总结 Thre...
    huangxiongbiao阅读 2,383评论 0 0
  • 我是黑夜里大雨纷飞的人啊 1 “又到一年六月,有人笑有人哭,有人欢乐有人忧愁,有人惊喜有人失落,有的觉得收获满满有...
    陌忘宇阅读 12,749评论 28 53

友情链接更多精彩内容