设计模式——迪米特法则

简介: 设计模式——迪米特法则

原则

又叫作最少知识原则(Least Knowledge Principle 简写LKP),就是说一个对象应当对其他对象有尽可能少的了解,不和陌生人说话。可以简单说成:talk only to your immediate friends。 对于OOD来说,又被解释为下面几种方式:一个软件实体应当尽可能少的与其他实体发生相互作用。每一个软件单位对其他的单位都只有最少的知识,而且局限于那些与本单位密切相关的软件单位。

特点

迪米特法则的初衷在于降低类之间的耦合。由于每个类尽量减少对其他类的依赖,因此,很容易使得系统的功能模块功能独立,相互之间不存在(或很少有)依赖关系。

迪米特法则不希望类之间建立直接的联系。如果真的有需要建立联系,也希望能通过它的友元类来转达。因此,应用迪米特法则有可能造成的一个后果就是:系统中存在大量的中介类,这些类之所以存在完全是为了传递类之间的相互调用关系——这在一定程度上增加了系统的复杂度。

总结

迪米特法则,如果两个类不必彼此直接通向,那么这两个类就不应当发生直接的相互作用。如果其中一个类需要调用另一个累哦的某一个方法的话,可以通过第三者转发这个调用。

面向对象的设计原则和面向对象的三大特性本就不是矛盾的。迪米特法则其根本思想,是强调了类之间的松耦合。类之间的耦合越弱,越有利于复用,一个处在弱耦合的类被修改,不会对有关系的类造成搏击,也就是说,信息的隐藏促进了软件的复用。

迪米特尤其适合做大型复杂系统设计指导原则。但是也会造成系统的不同模块之间的通信效率降低,使系统的不同模块之间不容易协调等缺点。


相关文章
|
8月前
|
设计模式 Java
Java设计模式七大原则-迪米特法则
Java设计模式七大原则-迪米特法则
37 0
|
12月前
|
设计模式 XML JSON
【Java设计模式 经典设计原则】七 LOD迪米特法则
【Java设计模式 经典设计原则】七 LOD迪米特法则
90 0
|
设计模式
设计模式 - 六大设计原则之LoD(迪米特法则原则)
迪米特法(Law Of Demeter , LoD)则又叫最少知道原则(Least Knowledge Principle),最早是在1987年由美国Northeastern University的Ian Holland提出。 通俗的来讲,就是一个类对自己依赖的类知道的越少越好。也就是说,对于被依赖的类来说,无论逻辑多么复杂,都尽量地的将逻辑封装在类的内部,对外除了提供的public方法,不对外泄漏任何信息。
136 0
设计模式 - 六大设计原则之LoD(迪米特法则原则)
|
设计模式
设计模式(6) -- 迪米特法则
设计模式(6) -- 迪米特法则
设计模式(6) -- 迪米特法则
|
设计模式
设计模式六大原则(五)----迪米特法则
设计模式六大原则(五)----迪米特法则
113 0
|
设计模式 Java
【Java设计模式】迪米特法则的详细介绍
【Java设计模式】迪米特法则的详细介绍
|
设计模式
寂然解读设计模式 - 迪米特法则
正确使用迪米特法则是可以让程序保证低耦合的,因为避免了与非直接的朋友通信,但是想要通信,就需要用到直接的朋友, 过分的使用迪米特原则,会产生很多这样没有必要的直接的朋友,导致系统复杂度变大,所以,在釆用迪米特法则时要进行权衡,保证系统的结构清晰
266 0
设计模式六大原则(5):迪米特法则
定义:一个对象应该对其他对象保持最少的了解。 问题由来:类与类之间的关系越密切,耦合度越大,当一个类发生改变时,对另一个类的影响也越大。 解决方案:尽量降低类与类之间的耦合。          自从我们接触编程开始,就知道了软件编程的总的原则:低耦合,高内聚。
1103 0