设计模式七大原则之迪米特法则

设计模式 专栏收录该内容
12 篇文章 0 订阅

简介

迪米特法则又叫“最少知道原则”,即一个类对自己依赖的类知道的越少越好(使他们之间有最低耦合度),对于依赖的类不管多复杂,都尽量把逻辑封装在类内部,对外出了提供public方法,不泄露任何的信息,最简单的说就是:只与直接的朋友通信

  • 那么,什么又叫“直接的朋友”呢?

每个对象都会与其他的对象之间产生耦合关系,只要两个对象之间存在耦合关系,我们就说他们是朋友;耦合有很多种方式,如:继承、依赖、聚合、组合等。其中,我们称出现在成员变量、方法参数、方法返回值(位置)中的类,这样的类为直接朋友;而出现在局部变量中的类不是直接朋友,即陌生的类最好不要以局部变量的形式出现在类的内部。

实例分享

  • 一个学校中,有总部及各个学院,现在要求打印出学校总部员工ID和各学院员工ID。

最初的代码:

//客户端
public class Demeter1 {

    public static void main(String[] args) {
        //创建了一个 SchoolManager 对象
        SchoolManager schoolManager = new SchoolManager();
        //输出学院的员工id 和  学校总部的员工信息
        schoolManager.printAllEmployee(new CollegeManager());
    }
}

//学校总部员工类
class Employee {
    private String id;

    public void setId(String id) {
        this.id = id;
    }

    public String getId() {
        return id;
    }
}


//学院的员工类
class CollegeEmployee {
    private String id;

    public void setId(String id) {
        this.id = id;
    }

    public String getId() {
        return id;
    }
}


//管理学院员工的管理类
class CollegeManager {
    //返回学院的所有员工
    public List<CollegeEmployee> getAllEmployee() {
        List<CollegeEmployee> list = new ArrayList<CollegeEmployee>();
        for (int i = 0; i < 10; i++) { //这里我们增加了10个员工到 list
            CollegeEmployee emp = new CollegeEmployee();
            emp.setId("学院员工id= " + i);
            list.add(emp);
        }
        return list;
    }
}

//学校管理类

//分析 SchoolManager 类的直接朋友类有 Employee(返回值)、CollegeManager(方法参数)
//CollegeEmployee 不是 直接朋友 而是一个陌生类,这样违背了 迪米特法则
class SchoolManager {
    //返回学校总部的员工
    public List<Employee> getAllEmployee() {
        List<Employee> list = new ArrayList<Employee>();

        for (int i = 0; i < 5; i++) { //这里我们增加了5个员工到 list
            Employee emp = new Employee();
            emp.setId("学校总部员工id= " + i);
            list.add(emp);
        }
        return list;
    }

    //该方法完成输出学校总部和学院员工信息(id)
    void printAllEmployee(CollegeManager collegeManager) {

        //分析问题
        //1. 这里的 CollegeEmployee 不是  SchoolManager的直接朋友(CollegeEmployee不是成员变量,也不是参数,也不是返回值),违反了迪米特法则,不是直接朋友,而是一个陌生类
        //2. CollegeEmployee 是以局部变量方式出现在 SchoolManager
        //3. 违反了 迪米特法则

        //获取到学院员工
        List<CollegeEmployee> list1 = collegeManager.getAllEmployee();
        System.out.println("------------学院员工------------");
        for (CollegeEmployee e : list1) {
            System.out.println(e.getId());
        }
        //获取到学校总部员工
        List<Employee> list2 = this.getAllEmployee();
        System.out.println("------------学校总部员工------------");
        for (Employee e : list2) {
            System.out.println(e.getId());
        }
    }
}

这一版的不足:在SchoolManager中,CollegeEmployee类并不是SchoolManager类的直接朋友,按照迪米特法则,应该避免这种非直接朋友的耦合关系存在,下面进行改进。

改进后的代码:

//客户端
public class Demeter1 {

	public static void main(String[] args) {
		System.out.println("用迪米特法则改进后的结果!");
		//创建了一个 SchoolManager 对象
		SchoolManager schoolManager = new SchoolManager();
		//输出学院的员工id 和  学校总部的员工信息
		schoolManager.printAllEmployee(new CollegeManager());
	}
}


//学校总部员工类
class Employee {
	private String id;

	public void setId(String id) {
		this.id = id;
	}

	public String getId() {
		return id;
	}
}


//学院的员工类
class CollegeEmployee {
	private String id;

	public void setId(String id) {
		this.id = id;
	}

	public String getId() {
		return id;
	}
}


//管理学院员工的管理类
class CollegeManager {
	//返回学院的所有员工
	public List<CollegeEmployee> getAllEmployee() {
		List<CollegeEmployee> list = new ArrayList<CollegeEmployee>();
		for (int i = 0; i < 10; i++) { //这里我们增加了10个员工到 list
			CollegeEmployee emp = new CollegeEmployee();
			emp.setId("学院员工id= " + i);
			list.add(emp);
		}
		return list;
	}

	//输出学院员工的信息
	public void printEmployee() {
		//获取到学院员工
		List<CollegeEmployee> list1 = getAllEmployee();
		System.out.println("------------学院员工------------");
		for (CollegeEmployee e : list1) {
			System.out.println(e.getId());
		}
	}
}

//学校管理类

//分析 SchoolManager 类的直接朋友类有哪些 Employee(返回结果)、CollegeManager(参数)
//CollegeEmployee 不是 直接朋友 而是一个陌生类,这样违背了 迪米特法则(CollegeEmployee既不是成员变量,也不是返回值,还不是参数)
class SchoolManager {
	//返回学校总部的员工
	public List<Employee> getAllEmployee() {
		List<Employee> list = new ArrayList<Employee>();

		for (int i = 0; i < 5; i++) { //这里我们增加了5个员工到 list
			Employee emp = new Employee();
			emp.setId("学校总部员工id= " + i);
			list.add(emp);
		}
		return list;
	}

	//该方法完成输出学校总部和学院员工信息(id)
	void printAllEmployee(CollegeManager collegeManager) {

		//分析问题
		//1. 将输出学院的员工方法,封装到CollegeManager
		collegeManager.printEmployee();

		//获取到学校总部员工
		List<Employee> list2 = this.getAllEmployee();
		System.out.println("------------学校总部员工------------");
		for (Employee e : list2) {
			System.out.println(e.getId());
		}
	}
}

小结

迪米特法则的核心: 降低类之间的耦合度

PS:由于每个类都减少了不必要的依赖,故迪米特法则只是要求降低类间(对象间)耦合度,并不是要求完全没有依赖关系。

  • 0
    点赞
  • 1
    评论
  • 0
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

相关推荐
©️2020 CSDN 皮肤主题: 技术工厂 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值