依赖倒转原则简述

1.高层模块不应该依赖低层模块,二者都应该依赖其抽象

2.抽象不应该依赖细节,细节应该依赖抽象

3.依赖倒转得中心思想时面向接口编程

4.依赖倒转原则时基于这样得设计理念:相对于细节得多变性,抽象得东西要稳定得多。以抽象为基础搭建的架构比以细节为基础搭建的架构要稳定得多。在java中,抽象指的时接口或是抽象类,细节就是具体得实现类

5.使用接口或抽象类的目的时规定好规范,而不涉及任何具体操作,把展现细节的任务交给他们的实现类完成

依赖倒转原则的三种实现方式

1.接口传递

2.构造方法传递

3.setter方式传递

应用实例

没有使用依赖倒转原则

public class DependecyInversion {
public static void main(String[] args) {
Person p = new Person();
p.receive(new Email());
}
} /*
* 完成Person接收消息的功能
*方式1分析
*1. 简单,比较容易想到
*2. 如果我们获取的对象是微信,短信等等,则新增类,同时Person类也要增加相应的接受方法
*3.解决思路:引入一个抽象的接口IReceiver,表示接收者,这样Person类 与接口IReceiver发生依赖
*因为Email,微信,等等属于接收的范围,他们各自实现IReceiver接口就ok了,这样我们就符合依赖倒转原则
*/
class Email{
public String getInfo() {
return "电子邮件信息:hello, world";
}
}
class Person{
public void receive(Email email) {
System.out.println(email.getInfo());
}
}

接口传递

public class DependecyInversionTest {
public static void main(String[] args) {
//方法1,通过接口实现
ChangHong changHong = new ChangHong(); //创建ChangHong类的对象
OpenAndClose openAndClose = new OpenAndClose(); //创建OpenAndClose类的对象
openAndClose.open(changHong); //通过接口实现
}
} //方式1:通过接口传递依赖
interface IOpenAndClose {
public void open(ITV tv);
} interface ITV {
public void play();
} class OpenAndClose implements IOpenAndClose{
public void open(ITV tv) {
tv.play();
}
} class ChangHong implements ITV{
public void play() {
System.out.println("打开");
}
}

构造方法传递

public class DependecyInversionTest {
public static void main(String[] args) {
//方法2,通过构造器实现
ChangHong changHong = new ChangHong(); //创建ChangHong类的对象
OpenAndClose openAndClose= new OpenAndClose(changHong); //创建OpenAndClose类的对象
openAndClose.open(); //通过构造器实现
}
} //方式2,通过构造方法依赖传递
interface IOpenAndClose {
public void open();
} interface ITV{
public void play();
} class OpenAndClose{
public ITV tv;
public OpenAndClose(ITV tv) {
this.tv = tv;
}
public void open() {
this.tv.play();
}
} class ChangHong implements ITV{ @Override
public void play() {
// TODO Auto-generated method stub
System.out.println("打开");
} }

setter方式传递

public class DependecyInversionTest {
public static void main(String[] args) {
//方法3,通过setter方式实现
ChangHong changHong = new ChangHong(); //创建ChangHong类的对象
OpenAndClose openAndClose = new OpenAndClose(); //创建ChangHong类的对象
openAndClose.setTV(changHong); //通过setter方式传递
openAndClose.open(); //调用open()方法
}
} //方式3,通过setter方法传递
interface IOpenAndClose{
public void open();
} interface ITV{
public void play();
} class ChangHong implements ITV{
public ITV tv;
public void play() {
System.out.println("打开");
}
} class OpenAndClose implements IOpenAndClose{
public ITV tv;
public void setTV(ITV tv) {
this.tv = tv;
}
public void open() {
this.tv.play();
}
}

最新文章

  1. 通过rsync搭建一个远程备份系统(二)
  2. php中并发读写文件冲突的解决方案(文件锁应用示例)
  3. python面向对象编程(下)
  4. logcat保存当前应用程序的日志并上传服务器或指定邮箱
  5. c#实现生产者消费者模式
  6. Gradle cookbook(转)
  7. 高校征信系统项目Postmortem结果
  8. jvm(一):总体概述
  9. className.class.getResourceAsStream与ClassLoader.getSystemResourceAsStream区别
  10. 【Linux基础】mount报错:mount.nfs: Remote I/O error
  11. python---自己实现双向链表常用功能
  12. Java学习-051-Detected both log4j-over-slf4j.jar AND bound slf4j-log4j12.jar on the class path, preempting StackOverflowError
  13. conda 常用命令
  14. vue中computed和watch
  15. jmeter 执行python脚本
  16. springboot整合zookeeper
  17. 通过USB转TTL串口下载stm32程序
  18. [No0000113]Keyboard shortcuts for Windows Visual Studio Code
  19. css:长度距离的一个计算函数calc
  20. 如何优化Mysql数据库

热门文章

  1. JDK 1.8 完整日期时间Api (文末附示例)
  2. Word文档分节设置页码
  3. Java:多线程概述与创建方式
  4. bjut校园网自动登录
  5. Android: Fragment编程指南
  6. centos7 手把手从零搭建深度学习环境 (以TensorFlow2.0为例)
  7. 再次聚焦DOCKER MACHINE CODE 2048
  8. github三步走(init;add . ;commit -m "提交说明")
  9. JMeter接口测试-接口签名校验
  10. pytorch之 activation funcion