设计模式之迪米特原则(LOD)(最少知识原则)

来源:
迪米特法则(LoD)最初是用来作为面向对象的系统设计风格的一种法则,是很多著名系统,如火星登陆软件系统、木星的欧罗巴卫星轨道飞船的软件系统的指导设计原则。

迪米特法则(LoD)又可分为两种:狭义的迪米特法则(LoD)和广义的迪米特法则(LoD)。

概念:

LOD:LOD,Law Of Demeter

迪米特法则又称最少知识原则,也就是说一个对象应当对其他对象有尽可能少的了解。

狭义的迪米特法则(LoD):

  • 如果两个类不必彼此直接通信,那么这两个类就不应当发生直接的相互作用。

  • 如果其中的一个类需要调用另一个类的某一个方法的话,可以通过第三者转发这个调用。

我们更为形象的来这样说:

  • “某人”与一个“朋友”组成自己的朋友圈,两个人都需要与一个圈外的“陌生人”发生相互作用。

  • “朋友” 与“陌生人”若是朋友,组成“朋友”的朋友圈。

  • “某人”并不需要与“陌生人”直接发生相互作用,而是通过“朋友”与之发生直接相互作用。

  • “朋友”实际起到了将“某人”对“陌生人”的调用转发给“陌生人”的作用。

可见,通过调用转发,隐藏了“陌生人”的存在,使得“某人”认为他所调用的方法是“朋友”的方法。

关键在于朋友圈的确定。 “朋友”的条件:

  • 当前对象本身(this)

  • 以参量形式传入到当前对象方法中的对象

  • 当前对象的实例变量直接引用的对象

  • 当前对象的实例变量如果是一个聚集,那么聚集中的元素也都是朋友

  • 当前对象所创建的对象。

任何一个对象,如果满足上述条件之一,就是当前对象的“朋友”;否则就是“陌生人”。

狭义的迪米特法则(LoD)的缺点:

  1. 遵循类之间的迪米特法则会使一个系统的局部设计简化,因为每个局部都不会与远距离的对象有直接的关联;但也会造成不同模块之间的通信效率降低,会使系统的不同模块之间不容易协调。

  2. 在系统中造出大量的小方法,散落在系统的各个角落。这些方法仅传递间接的调用,与系统的商务逻辑无关。

  3. 当设计师试图从一张类图中看出总体的架构时,这些小方法会造成迷惑和困扰。

改进办法:与依赖倒置原则互补使用

  • 引入一个抽象的类型引用“抽象陌生人”对象,使“某人”依赖于“抽象陌生人”,亦即将“抽象陌生人”变成“朋友”。

  • 只要新的具体的“陌生人”具有相同的抽象类型,那么某人就无法区分它们,从而允许“陌生人”的具体实现可独立于“某人”而变化。

广义的迪米特法则(LoD):

(1) 在类的划分上,应该创建有弱耦合的类;

(2)在类的结构设计上,每一个类都应当尽量降低成员的访问权限;

(3)在类的设计上,只要有可能,一个类应当设计成不变类;

(4)在对其他类的引用上,一个对象对其它对象的引用应当降到最低;

(5)尽量降低类的访问权限;

(6)谨慎使用序列化功能;

(7)不要暴露类成员,而应该提供相应的访问器(属性)。

相应设计模式:
Fa?ade
Mediator

设计原则间的关系:
在这一系列的文章中,我们介绍了几种设计原则,在这最后一个原则中,小结一下他们之间的关系:

SRP是基本
OCP是目的
DIP为手段
LSP是继承复用的基础
ISP是实现LoD的手段之一
CARP是复用的原则 
 多个原则应综合运用,共同达到目的----设计一个好的系统:可扩展性、灵活性、可插入性。

时间: 2024-11-06 13:30:06

设计模式之迪米特原则(LOD)(最少知识原则)的相关文章

设计模式——迪米特法则(最少知识原则)

迪米特法则: 如果两个类不必彼此直接通信,那么这两个类就不要发生直接的相互作用. 如果其中一个类需要调用另一个类的某一个方法的话,可以通过第三者转发这个调用. 迪米特法则首先强调的前提是:在类的结构设计上,每一个类都应该尽量降低成员的访问权限,也就是说,一个类包装好 自己的private状态,不需要让别的类知道的字段或行为就不要公开. 迪米特法则的根本思想是:强调了类之间的松耦合. 在程序设计的时候,类之间的耦合越弱,越有利于复用,一个处在弱耦合的类被修改,不会对有关系的类造成波及. 也就是说信

OOAD-8 面向对象设计七原则--迪米特法则/最少知识原则

迪米特法则的定义 迪米特法则又叫做最少知识原则.它的定义是:只与你的直接朋友交谈,不和陌生人说话.其含义是如果两个软件实体无须直接通信,那么就不应当发生直接的相互调用.可以通过第三方转发该调用.其目的是降低类之间的耦合度,提高模块之间的相对独立性 迪米特法则中的朋友是指:当前对象本身.当前对象的成员变量.当前对象所创建的对象.当前对象的方法参数等.这些对象同当前对象存在关联.聚合.组合关系,可以直接访问这些对象的方法. 狭义理解:一个对象应该对其他对象有最少的了解.通俗的将,一个类应该对自己需要

迪米特法则(LoD),即最少知识原则

解释: 如果两个类不必彼此直接通信,那么这两个类就不应当发生直接的相互作用.如果其中一个类需要调用另一个类的某一个方法的话,可以通过第三者转发这个调用. 重点: 在类的结构上,每个类都应当尽量降低成员的访问权限. 即,一个类包装好自己的private状态,不需要让别的类知道的字段或行为就不要公开. 根本思想: 强调了类之间的松耦合. 类之间的耦合越弱,越有利于复用,一个处在弱耦合的类被修改,不会对有关系的类造成波及. 即,信息的隐藏促进了软件的复用

设计模式六大原则/接口设计六大原则 之 迪米特法则(转)

定义:一个对象应该对其他对象保持最少的了解.迪米特法则(Law of Demeter)又叫作最少知识原则(Least Knowledge Principle 简写LKP),就是说一个对象应当对其他对象有尽可能少的了解,不和陌生人说话.英文简写为: LoD. 目的:迪米特法则的初衷在于降低类之间的耦合.由于每个类尽量减少对其他类的依赖,因此,很容易使得系统的功能模块功能独立,相互之间不存在(或很少有)依赖关系. 迪米特法则不希望类之间建立直接的联系.如果真的有需要建立联系,也希望能通过它的友元类来

设计模式--迪米特法则(Lod/LKP)

迪米特法则:(Law of Demeter, LoD),也称最少知识原则(Least Knowledge Principle, LKP) 理解: 如果两个类不必彼此直接通信,那么这两个类就不应该发生直接的相互作用.如果其中一个类需要调用另一个类的某一个放发的话,可以通过第三者转发这个调用. 只和朋友交流(更准确来讲是:直接的朋友) 每个对象都必然会与其他对象有耦合关系,两个对象之间的耦合就成为朋友关系,这种关系的类型有很多,如组合.聚合.依赖等. 朋友类的定义:出现在成员变量.方法的输入输出参数

5迪米特法则LoD

一.什么是迪米特法则 迪米特法则(Law of Demeter )又叫做最少知识 原则,也就是说,一个对象应当对其他对象尽可 能少的了解. 迪米特法则最初是用来作为面向对象的系统设 计风格的一种法则,于1987年秋天由lan holland 在美国东北大学为一个叫做迪米特的项目设计提 出的. 二.狭义的迪米特法则 如果两个类不必彼此直接通信,那么这两个类 就不应当发生直接的相互作用.如果其中一个类 需要调用另一类的某一个方法的话,可以通过第 三者转发这个调用. 三.和陌生人说话 四.不要和陌生人

java设计原则:16种原则

一   类的设计原则   1 依赖倒置原则-Dependency Inversion Principle (DIP) 2 里氏替换原则-Liskov Substitution Principle (LSP) 3 接口分隔原则-Interface Segregation Principle (ISP) 4 单一职责原则-Single Responsibility Principle (SRP) 5 开闭原则-The Open-Closed Principle (OCP) 二  包的设计原则   6

设计模式六大原则之里氏替换原则

一.概念: 里氏替换原则:LSP (Liskov Substitution Principle),如果对每一个类型为T1的对象o1,都有类型为T2的对象o2,使得以T1定义的所有程序P在所有的对象o1都换成o2时,程序P的行为没有变化,那么类型T2是类型T1的子类型. 通俗的定义:所有引用基类的地方必须能透明地使用其子类的对象. 二.例子: 以浇水为例.人,拿到工具[水管.水桶.瓶子],装水后都可以浇水.[水管.桶.瓶子]都可以获取水.应该有个loadWater方法.有watering 浇水功能

设计模式之6大原则(6)开闭原则

1. more第一版 实现基础功能,显示每一页固定24行文本,"q Enter"退出, "Enter" 下一行, "space Enter"下一页. /************************************************************************* > File Name: more01.c > Author: qianlv > Mail: [email protected] &