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

文章目录

基本介绍

  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();
	}

}

不至于造成资源浪费!

相关推荐
JH30734 小时前
SpringBoot 优雅处理金额格式化:拦截器+自定义注解方案
java·spring boot·spring
Coder_Boy_5 小时前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
invicinble5 小时前
对tomcat的提供的功能与底层拓扑结构与实现机制的理解
java·tomcat
较真的菜鸟5 小时前
使用ASM和agent监控属性变化
java
黎雁·泠崖5 小时前
【魔法森林冒险】5/14 Allen类(三):任务进度与状态管理
java·开发语言
qq_12498707537 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计
Coder_Boy_7 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
Mr_sun.7 小时前
Day06——权限认证-项目集成
java
瑶山7 小时前
Spring Cloud微服务搭建四、集成RocketMQ消息队列
java·spring cloud·微服务·rocketmq·dashboard
abluckyboy7 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法