六大原则(5)——迪米特法则

迪米特法则

概述

定义

一个对象应该对其他对象保持最少的了解。

问题由来

类与类之间的关系越密切,耦合度越大,当一个类发生改变时,对另一个类的影响也越大。

解决方案

尽量降低类与类之间的耦合。

迪米特法则又叫最少知道原则。通俗的来讲,就是一个类对自己依赖的类知道的越少越好。也就是说,对于被依赖的类来说,无论逻辑多么复杂,都尽量地的将逻辑封装在类的内部,对外除了提供的public方法,不对外泄漏任何信息。迪米特法则还有一个更简单的定义:只与直接的朋友通信。首先来解释一下什么是直接的朋友:每个对象都会与其他对象有耦合关系,只要两个对象之间有耦合关系,我们就说这两个对象之间是朋友关系。耦合的方式很多,依赖、关联、组合、聚合等。其中,我们称出现成员变量、方法参数、方法返回值中的类为直接的朋友而出现在局部变量中的类则不是直接的朋友。也就是说,陌生的类最好不要作为局部变量的形式出现在类的内部。

有哪些设计模式遵循了迪米特法则

外观模式。外观模式对客户端屏蔽子系统,客户端不需要了解子系统,直接访问外观类即可

命令模式。请求者和接受者之间不存在直接引用,实现了解耦。

中介者模式。中介者模式将各同事解耦,实现了“一个对象应当对其他对象保持最少的了解”

举例

小明妈妈要求小明做作业

下面的例子违反迪米特法则

    public static void main(String args[]){
        Mom mom = new Mom();
        mom.order();
    }

    static class Chinese{
        public String getName(){
            return "语文作业";
        }
    }

    static class Xiaoming{
        Chinese mChinese = new Chinese();

        public Chinese getChinese() {
            return mChinese;
        }
    }

    static class Mom{
        private Xiaoming mXiaoming = new Xiaoming();
        public void order(){
            //mXiaoming.getChinese().getName() 违反迪米特法则
            System.out.println("小明正在做" + mXiaoming.getChinese().getName());

        }
    }

如注释,一般这样的调用形式 A.getXxx().dosometing()都会违反迪米特法则,就像例子中,妈妈的直接朋友是小明,语文作业和她并不是直接朋友关系,所以妈妈并不需要知道它的细节,比如妈妈不应该知道小明要做的是语文作业,只要小明做作业就好了,更细致的说,应该是妈妈不应该知道小明的语文作业有getName()这个方法,因为假设以后getName()方法改为了getTitle或者其他改变,在Mom这个类也要做相对应的改变,所以两者应该相隔离开,所以正确的做法如下

    public static void main(String args[]){
        Mom mom = new Mom();
        mom.order();
    }

    static class Chinese{
        public String getName(){
            return "语文作业";
        }
    }

    static class Xiaoming{
        Chinese mChinese = new Chinese();

        public void doHomework(){
            System.out.println("小明正在做" + mChinese.getName());
        }
    }

    static class Mom{
        private Xiaoming mXiaoming = new Xiaoming();
        public void order(){
        //只要求小明做作业,做什么作业不管
            mXiaoming.doHomework();
        }
    }

注意事项

迪米特法则的初衷是降低类之间的耦合,由于每个类都减少了不必要的依赖,因此的确可以降低耦合关系。但是凡事都有度,虽然可以避免与非直接的类通信,但是要通信,必然会通过一个“中介”来发生联系,过分的使用迪米特原则,会产生大量这样的中介和传递类,导致系统复杂度变大。所以在采用迪米特法则时要反复权衡,既做到结构清晰,又要高内聚低耦合。

你可能感兴趣的:(6大原则)