重构 — 改善既有的类图设计 条款4:消除重复的依赖关系

重构 — 改善既有的类图设计
条款4:消除重复的依赖关系

黄国强 2008/5/12

图 1
见 图1。图中,类 A 因为调用了类 B ,所以有一条从类 A 指向类 B 的箭头。同时类 A 又调用了类 C,所以有一根从类 A 指向类 C 的箭头。由于类 B 也有一根指向类 C 的箭头,所以为了消除重复的依赖关系,我们将类 A 指向类 C 的箭头去掉。重构后的设计见图 2。
图 2
解释一下,重构后的第一个好处就是图比以前跟简洁了。另外一个好处不太明显,根据迪米特法则。由于类 B 和类 C 是朋友,所以,发给类 C 的消息可以由类 B 转发。这样的设计将类 A 与类 C 的直接关系去除了。从而有利于未来的重构。 迪米特法则(Law of Demeter)的解释: 迪米特法则说的是一个对象应该对其它对象有尽可能少的了解。即只与你直接的朋友通信,不要跟陌生人说话。如果需要和陌生人通话,而你的朋友与陌生人是朋 友,那么可以将你对陌生人的调用由你的朋友转发,使得某人只知道朋友,不知道陌生人。换言之,某人会认为他所调用的是朋友的方法。

相关文章

什么是设计模式一套被反复使用、多数人知晓的、经过分类编目...
单一职责原则定义(Single Responsibility Principle,SRP)...
动态代理和CGLib代理分不清吗,看看这篇文章,写的非常好,强...
适配器模式将一个类的接口转换成客户期望的另一个接口,使得...
策略模式定义了一系列算法族,并封装在类中,它们之间可以互...
设计模式讲的是如何编写可扩展、可维护、可读的高质量代码,...