美文网首页
换个角度理解之OOP三原则

换个角度理解之OOP三原则

作者: 夫礼者 | 来源:发表于2017-11-26 00:26 被阅读60次

继续我们的系列。

三原则的内容和基本内容就不谈了,说出来都得被骂矫情。让我们直接进入正题。

1. 封装

封装,也就是黑盒了。这里我们回顾下核心准则就明了了——“相比较应该知道自己该知道什么,清楚地认识到自己不该知道什么甚至更重要。因为前者一般人都或多或少知道一部分,而后者需要的更多是自信。而且忽略掉其它细节才能让我们集中全部精力解决我们真正关心的问题”。

封装的含义上面这段话基本解释得很清楚了:

  1. 从使用者的角度来说就是我对这里面的实现细节不关心,你直接告诉我你要些啥才能给我所想要的结果。
  2. 而从服务者的角度则是这里面的逻辑你就别关心了,我会保证结果正确的。而且搞不好以后我还会换种实现方式。

2. 继承

最主要的职责就是避免重复了。类似《Clean Code》,《程序员修炼之道——从小工到专家》等极其多的名著里都一再强调重复的危害。而《Clean Code》甚至直接断言”软件行业里的大部分改进就是为了消除重复”。

3. 多态

”同样的行为作用于不同的个体产生不同的效果”。以上是生物学上对多态的定义。(当初小白入行,为了搞懂多态的定义,居然死磕着把定义背下来了。嗯,青春岁月。)

关于这个OOP原则,就涉及到另外一个核心原则——“推迟作出决定的时机”。这里我得引用下我之前一篇文章里的论点了:

  1. 很多时候我们不想要被此时的决定束缚住手脚,导致之后的工作因当前的决定而步履维艰。但我们又必须作出某种决定以便让接下来的工作得以进行,于是我们可以假装实现了这个功能(假装已经做出了这个决定)来让工作得以继续; 待到真正需要这个功能时,才去实现它(真正地做出来决定)。使用这种方法可以让我们的程序变得非常稳固,能够自如地应对外界的变化。
  2. 上面的”假装实现了这个功能”的另外一种说法叫做“wishful thinking”。有兴趣的读者可以了解下,很有意思的。或者直接看本人底部的链接。而”假装实现了这个功能”的一种实现方式就是声明一个接口。
  3. 而建立接口的目的就是为了推迟作决定的时机。
    1. 定义接口就是假装作出了这个决定。
    2. 而实现接口则是真正地作出这个决定。
    3. 上面两个行为是有时间差的。而且这个时间差越大,你的程序就越灵活。
    4. 熟悉Java的同学应该都知道多态属于一种 动态绑定 吧。所谓的动态绑定不就是到真正需要的时候才去找实现者吗?

4. 扩展阅读

  1. http://www.jianshu.com/p/5a94c15a3278

相关文章

  • 换个角度理解之OOP三原则

    继续我们的系列。 三原则的内容和基本内容就不谈了,说出来都得被骂矫情。让我们直接进入正题。 1. 封装 封装,也就...

  • 换个角度理解之银弹

    《换个角度理解之设计模式》的草稿已经放了一个多月了,始终感觉缺少点什么。最近因为工作需要在读Shiro,Thyme...

  • 换个角度理解

    很高兴最近认识了一个很有趣的老师,在我眼里,他简直就是一个挂着老师名头的大哲学家啊!我还是第一次,听到有人如此去理...

  • 换个角度理解之设计模式

    这里以经典的二十三种来进行讨论。 概述 其实这个主题在本系列创建之初就建好了,但自感对于设计模式的理解还处于小学生...

  • 换个角度理解锁

    隔了窗户纸 说到锁,各种书籍或者博客上嗖嗖嗖就能上来一堆关于锁的名词,比如读写锁、互斥锁、自旋锁,等等。然后介绍这...

  • 换个角度理解——总览

    思想来源于《SICP》,《Clean Code》,《程序员的修炼之道——小工到专家》等经典,结合本人初级的实践经验...

  • 换个角度理解梯度

    https://www.zhihu.com/question/36301367/answer/198887937

  • 换个角度理解 DFT

    学校里面教的 学校里面基本都是说是把时域变换到频域等等,然后给一个公式, 然后当时虽然尽力在理解,但是仔细想起来,...

  • 换个角度理解“现实”

    今年突如其来的疫情,这只黑天鹅,使全球经济又进去了下挫,美国股市两天熔断,让人们感到这世界是怎么了? 而封闭在家的...

  • 换个角度理解之AOP与IOC

    老生常谈的话题,所以我这里所说的内容当然不能是一些老掉牙,被人咀嚼了无数次的残渣。我争取从一个特别的角度给你留下别...

网友评论

      本文标题:换个角度理解之OOP三原则

      本文链接:https://www.haomeiwen.com/subject/eircbxtx.html