博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
读Clean Code - 数据结构和对象
阅读量:6679 次
发布时间:2019-06-25

本文共 1285 字,大约阅读时间需要 4 分钟。

最近在上下班挤公交的时间细阅Clean Code(代码整洁之道),再次佩服Bob大叔幽默的文笔,独到的观点和理解视角。最让我耳目一新的是Bob大叔对数据结构和对象的解释。

     总的说来数据结构指的就是数据的载体,暴露数据,而几乎没有有意义的行为,你应该在尖叫这不是贫血类?的确这和我们的贫血类很相似。最常见的应用在分布式服务,以wcf,webservice,reset之类的分布式服务中不可或缺的数据传输对象(DTO)模式,DTO(Request/Response)就是一个很典型的数据载体,只存在简单的get,set属性,并且更倾向于作为值对象存在。而对象则刚好相反作为面向对象的产物,必须封装隐藏数据,而暴露出行为接口,DDD中领域模型倾向于对象不仅在数据更多暴露行为操作自己或者关联状态。

     虽然数据结构和对象之间看是细微的差别却导致了不同的本质区别:使用数据结构的代码便于在不改动现在数据结构的前提下添加新的行为(函数),面向对象代码则便于不改动现 有函数的前提下添加新的类。换句话说就是数据结构难以添加新的的数据类型,因为需要改动所有函数,面向对象的代码则难以添加新的函数,因为需要修改所有的类。在任何一个复杂的系统都会同时存在数据结构和对象,我们需要判断的是我们需要的是需要添加的新的数据类型还是新的行为函数。

在则就是迪米特法则,或被译为最小知识原则,不和陌生人说话:模块不应该了解他所操作的对象的内部情形,关于对象的隐藏,更细致的理解为一个对象A的方法f,应该也只能调用对象为下列范围内:

  1. 对象A的属性字段
  2. 对象A持有的对象
  3. 方法参数传入的对象
  4. 在方法f中定义的临时对象

     方法不应和任何调用方法返回的对象操作,换句话之和朋友说话,不和陌生人说话。比如:ctxt.getOptions().getSearchDir().getAbsolutePath(),就是迪米特法则的反例模式。

     但当前迪米特法则的前提是对象,如果是数据结构,没有什么行为,则他们自然会暴露其内部数据结构,迪米特法则也失效了。

     隐藏作为面向对象主要特性中的最重要特性,封装隐藏是面向对象中最重要的特性,一个好的面向对象代码肯定是对对象的内部细节做到很好的隐藏封装,封装过后才有是多态,委派之类的。一个好的面向对象的代码一定是具有很好的隐藏封装,易于测试,不稳定因素往往集中在一处很小或者固定的位置,不稳定因素的变更不会导致更大面积的修改扩散。

     最后推荐下一本书籍,值得在空闲时间看看,不能保证看完代码就一定写出整洁的代码,做到童子军军规“每次签入的代码比签出的更整洁”,更不会像优美的散文,这需要在项目实践中不断练习发现,但对代码质量意思有着引导作用。

     总感觉自己的技术还差得很远,所以我总是约束自己抽出可用的时间看些书籍,从不同的视角,不同的领域或者一些思想的提升和沉淀。

关于面向对象原则随笔还有:

  1.  
本文转自破狼博客园博客,原文链接:http://www.cnblogs.com/whitewolf/archive/2012/07/12/2588896.html,如需转载请自行联系原作者
你可能感兴趣的文章
使用servlet API作为参数
查看>>
mysql 大数据提取
查看>>
centos7系统下nginx安装并配置开机自启动操作
查看>>
线性表 - 链式存储结构
查看>>
Python encode() 方法(转)
查看>>
《Android进阶之光》--Android新特性
查看>>
laydate 和 Vue 奇怪的清空问题
查看>>
洛谷P4016 负载平衡问题(最小费用最大流)
查看>>
微软文档
查看>>
jquery.dataTables列中内容居中问题?求解?
查看>>
ceph 底层代码分享
查看>>
vivado 的调试工具ILA抓到的波形可以保存
查看>>
SpringBoot(三):springboot启动参数
查看>>
2015小米暑期实习笔试题_风口的猪-中国牛市(dp)
查看>>
Modelsim添加Lattice库
查看>>
体验h5离线缓存
查看>>
MVC教程六:视图的寻址
查看>>
制作chrome插件/扩展程序,禁止谷歌浏览器访问某些网站
查看>>
查看某一职责下对应的菜单&功能&请求(转)
查看>>
【spring data jpa】启动报错:nested exception is java.util.NoSuchElementException
查看>>