软件维护与迪米特法则

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值