一、定义
迪米特法则(Law of Demeter,LoD)也称为最少知识原则(Least Knowledge Principle,LKP):一个对象应该对其他对象有最少的了解
。
英文解释:Only talk to your immediate friends.(只与直接的朋友通信)
二、举例
只和朋友交流
情景:老师让体育委员清点全班女生人数,类图如下:
很明显,类Teacher依赖了非朋友类——Girl类,那么问题来了什么是朋友类?答:朋友类的定义是出现在新成员变量或是方法的输入输出参数中的类
。
改正后的类图如下:
PS:一个方法尽量不要引入一个类中不存在的对象
。
朋友之间也有距离
情景:安装软件,类图如下:
在InstallSoftware类中会一次调用Wizard类的公开方法,但问题就出在Wizard类暴露太多的方法,若Wizard类的first方法改动,InstallSoftware类也必须改变,因此我们改进后类图如下:
将前三个方法设为私有,仅暴露安装的方法,实现高内聚、低耦合。
PS: 尽量使用private、package-private、protected等权限,不要公布太多pulbic方法
。
三、优点
高内聚、低耦合、减少由变更引起的风险
四、最佳实践
迪米特法则的核心是类间接偶,弱耦合。但需要把握一个“度”,既做到结构清晰,又做到高内聚低耦合。