设计模式——接口隔离原则

文章目录

基本介绍

  1. 客户端不应该依赖它不需要的接口,即一个类对另一个类的依赖应该建立在最小的接口上
  2. 先看一张图:
  1. 类 A 通过接口 Interface1 依赖类 B,类 C 通过接口 Interface1 依赖类 D,如果接口 Interface1 对于类 A 和类 C来说不是最小接口,那么类 B 和类 D 必须去实现他们不需要的方法。
  2. 按隔离原则应当这样处理:
    将接口 Interface1 拆分为独立的几个接口(这里我们拆分成 3 个接口),类 A 和类 C 分别与他们需要的接口建立依赖关系。也就是采用接口隔离原则

应用实例

  1. 类 A 通过接口 Interface1 依赖类 B,类 C 通过接口 Interface1 依赖类 D,请编写代码完成此应用实例。
  2. 看代码-没有使用接口隔离原则代码
java 复制代码
public class Segregation1 {
	public static void main(String[] args) {
		
		A a = new A();
		a.depend1(new B());
		//无法调用,即B中的 方法 白写了,造成了浪费.
		a.depend4(new B());
		
	}
}

interface Interface1 {

	void operation1();

	void operation2();

	void operation3();

	void operation4();

	void operation5();
}

class B implements Interface1 {

	@Override
	public void operation1() {
		// TODO Auto-generated method stub
		System.out.println("B中实现了 operation1");
	}

	@Override
	public void operation2() {
		// TODO Auto-generated method stub
		System.out.println("B中实现了 operation2");
	}

	@Override
	public void operation3() {
		// TODO Auto-generated method stub
		System.out.println("B中实现了 operation3");
	}

	@Override
	public void operation4() {
		// TODO Auto-generated method stub
		System.out.println("B中实现了 operation4");
	}

	@Override
	public void operation5() {
		// TODO Auto-generated method stub
		System.out.println("B中实现了 operation5");
	}

}

class D implements Interface1 {

	@Override
	public void operation1() {
		// TODO Auto-generated method stub
		System.out.println("D中实现了 operation1");
	}

	@Override
	public void operation2() {
		// TODO Auto-generated method stub
		System.out.println("D中实现了 operation2");
	}

	@Override
	public void operation3() {
		// TODO Auto-generated method stub
		System.out.println("D中实现了 operation3");
	}

	@Override
	public void operation4() {
		// TODO Auto-generated method stub
		System.out.println("D中实现了 operation4");
	}

	@Override
	public void operation5() {
		// TODO Auto-generated method stub
		System.out.println("D中实现了 operation5");
	}

}

class A { // A类通过接口 依赖(使用B类) 但是只会用到1,2,3方法
	public void depend1(Interface1 i) {
		i.operation1();
	}

	public void depend2(Interface1 i) {
		i.operation2();
	}

	public void depend3(Interface1 i) {
		i.operation3();
	}

}

class C { // C类通过接口 依赖(使用B类) 但是只会用到1,4,5方法
	public void depend1(Interface1 i) {
		i.operation1();
	}

	public void depend2(Interface1 i) {
		i.operation5();
	}

	public void depend3(Interface1 i) {
		i.operation5();
	}

}

应传统方法的问题和使用接口隔离原则改进

  1. 类 A 通过接口 Interface1 依赖类 B,类 C 通过接口 Interface1 依赖类 D,如果接口 Interface1 对于类 A 和类 C来说不是最小接口,那么类 B 和类 D 必须去实现他们不需要的方法
  2. 将接口 Interface1 拆分为独立的几个接口,类 A 和类 C 分别与他们需要的接口建立依赖关系。也就是采用接口隔离原则
  3. 接口 Interface1 中出现的方法,根据实际情况拆分为三个接口
  1. 代码实现
java 复制代码
public class Segregation2 {
	public static void main(String[] args) {

		A a = new A();

		a.depend1(new B()); // A类 通过接口依赖B类

		a.depend2(new B());

		a.depend3(new B());

		C c = new C();
		c.depend1(new D()); // C类通过接口 去依赖(使用)D类
		c.depend2(new D());
		c.depend3(new D());
	}
}

//接口1
interface Interface1 {

	void operation1();

}

//接口2
interface Interface2 {

	void operation2();

	void operation3();
}

//接口3
interface Interface3 {

	void operation4();

	void operation5();

}

class B implements Interface1, Interface2 {

	@Override
	public void operation1() {
		// TODO Auto-generated method stub
		System.out.println("B中实现了 operation1");
	}

	@Override
	public void operation2() {
		// TODO Auto-generated method stub
		System.out.println("B中实现了 operation2");
	}

	@Override
	public void operation3() {
		// TODO Auto-generated method stub
		System.out.println("B中实现了 operation3");
	}

}

class D implements Interface1, Interface3 {

	@Override
	public void operation1() {
		// TODO Auto-generated method stub
		System.out.println("D中实现了 operation1");
	}

	@Override
	public void operation4() {
		// TODO Auto-generated method stub
		System.out.println("D中实现了 operation4");
	}

	@Override
	public void operation5() {
		// TODO Auto-generated method stub
		System.out.println("D中实现了 operation5");
	}

}

class A { // A类通过接口 依赖(使用B类) 但是只会用到1,2,3方法
	public void depend1(Interface1 i) {
		i.operation1();
	}

	public void depend2(Interface2 i) {
		i.operation2();
	}

	public void depend3(Interface2 i) {
		i.operation3();
	}

}

class C { // C类通过接口 依赖(使用B类) 但是只会用到1,4,5方法
	public void depend1(Interface1 i) {
		i.operation1();
	}

	public void depend2(Interface3 i) {
		i.operation4();
	}

	public void depend3(Interface3 i) {
		i.operation5();
	}

}

不至于造成资源浪费!

相关推荐
AronTing2 分钟前
12- Java虚拟线程(Project Loom)深度解析:原理、实战与性能调优
java·后端·面试
顾林海9 分钟前
深度解析LinkedHashSet工作原理
android·java·面试
创码小奇客13 分钟前
Java 对象变形记:BeanUtils 与 MapStruct 的高阶魔法实战
java·spring boot·trae
申城异乡人25 分钟前
Spring RestTemplate使用方法总结
java
搞不懂语言的程序员26 分钟前
中介者模式详解及真实场景解决方案
设计模式·中介者模式
有诺千金1 小时前
深入理解 Spring Boot 的@AutoConfiguration注解
java·spring boot·后端
代码吐槽菌1 小时前
基于SpringBoot的律师事务所案件管理系统【附源码】
java·数据库·spring boot·后端·毕业设计
flzjkl1 小时前
【源码】【Java并发】【ReentrantLock】适合中学者体质的ReentrantLock源码阅读
java·后端
freejackman1 小时前
Java 环境配置
java·后端·java ee
bug菌1 小时前
领导安排我一小时实现一个导出功能,我竟用@Excel注解两分钟搞定!🫠
java·后端·spring