最少知识原则(Least Knowledge Principle,LKP)又叫作迪米特法则(Law of Demeter,LoD),它的定义是:只与你的直接朋友交谈,不跟“陌生人”说话。

其含义是:如果两个软件实体无须直接通信,那么就不应当发生直接的相互调用,可以通过第三方转发该调用。其目的是降低类之间的耦合度,提高模块的相对独立性。

迪米特法则中的“直接朋友”包含:

1.当前对象本身

2.当前对象的成员对象

3.当前对象所创建的对象

4.当前对象的方法参数

5.当前对象的方法返回值

这些对象同当前对象存在关联、聚合或组合关系,可以直接访问这些对象的方法。

 

迪米特法则要求限制软件实体之间通信的宽度和深度,正确使用迪米特法则将有以下两个优点。

1.降低了类之间的耦合度,提高了模块的相对独立性。

2.由于亲合度降低,从而提高了类的可复用率和系统的扩展性。

但是,过度使用迪米特法则会使系统产生大量的中介类,从而增加系统的复杂性,使模块之间的通信效率降低。

所以,在釆用迪米特法则时需要反复权衡,确保高内聚和低耦合的同时,保证系统的结构清晰。

 

从迪米特法则的定义和特点可知,它强调以下两点:

1.从依赖者的角度来说,只依赖应该依赖的对象。

2.从被依赖者的角度说,只暴露应该暴露的方法。

所以,在运用迪米特法则时要注意以下6点:

1.在类的划分上,应该创建弱耦合的类。类与类之间的耦合越弱,就越有利于实现可复用的目标。

2.在类的结构设计上,尽量降低类成员的访问权限。

3.在类的设计上,优先考虑将一个类设置成不变类。

4.在对其他类的引用上,将引用其他对象的次数降到最低。

5.不暴露类的属性成员,而应该提供相应的访问器(set 和 get 方法)。

6.谨慎使用序列化(Serializable)功能。

 

posted on 2019-10-29 20:27  Sempron2800+  阅读(1017)  评论(0编辑  收藏  举报