一、定义
依赖倒置原则的原始定义为:
- 高层模块不应该依赖低层模块,两者都应该依赖其抽象;
- 抽象不应该依赖细节,细节应该依赖抽象;
- 依赖倒装的中心思想就是:面向接口编程;
依赖倒置原则是实现开闭原则的重要途径之一,它降低了客户与实现模块之间的耦合。他的设计理念是这样子的,相对于细节的多变性,抽象的东西要稳定得多。以抽象为基础的架构比以细节搭建的架构要稳定得多。在java中,抽象指的就是接口或者是抽象类,细节就是具体的实现类。
使用接口或者抽象类的目的是制定好规范和契约,而不去涉及任何具体的操作,把展现细节的任务交给它们的实现类去完成。
二、依赖倒置的好处
依赖倒置原则的主要作用如下。
- 依赖倒置原则可以降低类间的耦合性。
- 依赖倒置原则可以提高系统的稳定性。
- 依赖倒置原则可以减少并行开发引起的风险。
- 依赖倒置原则可以提高代码的可读性和可维护性。
三、应用实例
下面就以客户接收消息的例子来说明依赖倒置原则。下面先展示一个不遵守依赖倒置原则的例子。
public class DependecyInversion {
public static void main(String[] args) {
Person person = new Person();
person.receive(new Email());
}
}
class Email {
public String getInfo() {
return "电子邮件信息: hello,world";
}
}
//完成Person接收消息的功能
//方式1分析
//1. 简单,比较容易想到
//2. 如果我们获取的对象是 微信,短信等等,则新增类,同时Perons也要增加相应的接收方法
//3. 解决思路:引入一个抽象的接口IReceiver, 表示接收者, 这样Person类与接口IReceiver发生依赖
// 因为Email, WeiXin 等等属于接收的范围,他们各自实现IReceiver 接口就ok, 这样我们就符号依赖倒转原则
class Person {
public void receive(Email email ) {
System.out.println(email.getInfo());
}
}
可以看到,如果我们获取的对象是 微信,短信等等,则新增类,同时Perons也要增加相应的接收方法,这样子就违反了开闭原则。那我们解决的思路就是:引入一个抽象的接口IReceiver, 表示接收者, 这样Person类与接口IReceiver发生依赖,因为Email, WeiXin 等等属于接收的范围,他们各自实现IReceiver 接口就ok, 这样我们就符号依赖倒转原则。
下面我们来看下改善之后的案例:
public class DependecyInversion {
public static void main(String[] args) {
//客户端无需改变
Person person = new Person();
person.receive(new Email());
person.receive(new WeiXin());
}
}
//定义接口
interface IReceiver {
public String getInfo();
}
class Email implements IReceiver {
public String getInfo() {
return "电子邮件信息: hello,world";
}
}
//增加微信
class WeiXin implements IReceiver {
public String getInfo() {
return "微信信息: hello,ok";
}
}
//方式2
class Person {
//这里我们是对接口的依赖
public void receive(IReceiver receiver ) {
System.out.println(receiver.getInfo());
}
}
依赖倒转原则的实现方法需要注意一下几点:
- 每个类应该尽量提供接口或者是抽象类;
- 变量的声明应该尽量是接口或者是抽象类;
- 任何类都不应该由具体的类派生;
- 使用继承的时候应该要遵循里氏替换原则;