你的灯亮着吗?

发现问题的真正所在。

导航

软件维护与迪米特法则

    最近在维护公司的一个旧项目的时候,发现有些BUG改了又改,子生孙,孙又生子的。公司里只要接触过这个项目的同事都觉得非常的痛苦。一个对象的状态被七八个地方修改,经常是这边改成这样,那边又改成这样,这边对了,那边又错了。几经思考,我认为这是违反了迪米特法则导致的。
    迪米特法则(Law of Demeter)又叫最少知识原则(Least Knowledge Principle 简写LKP)就是说,一个对象应当对其它对象有尽可能少的了解, 也叫做不要和陌生人说话。朋友越多,当然就越好了,在家靠父母,在外靠朋友嘛。为什么在面向对象设计里反而成了不好的事情呢?其实这是了对象不受到其它对 象太多的影响。就像革命时期情报员只能单线联系一样,如果其中一个被敌人发现了,其他人不会马上全部都暴露出来。系统里的对象改了某个方法或者被删除了, 它只会影响到与它有关联的对象。如果一个对象知道得太多其它的对象,只要其中的某一个对象有改变那它肯定就会受到影响。它知道的对象越多,可能受到影响就 会越多。虽然在现代的语言里(C#、Java等)可以使用接口来隔离变化,但是如果连接口都需要改变的时候,依然还是会受到的影响。遵守
迪米特法则可以使对象本身受到其它对象的影响降低到最少。

posted on 2007-08-22 09:19  热血青年  阅读(338)  评论(1编辑  收藏  举报