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

文章目录

基本介绍

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

}

不至于造成资源浪费!

相关推荐
汝生淮南吾在北2 小时前
SpringBoot+Vue饭店点餐管理系统
java·vue.js·spring boot·毕业设计·毕设
冬夜戏雪5 小时前
【java学习日记】【2025.12.7】【7/60】
java·开发语言·学习
CC.GG5 小时前
【C++】二叉搜索树
java·c++·redis
JIngJaneIL7 小时前
基于Java非遗传承文化管理系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot
南部余额7 小时前
踩坑与解惑:深入理解 SpringBoot 自动配置原理与配置排除机制
java·spring boot·自动配置原理·import
木鹅.8 小时前
LangChain4j
java
永远都不秃头的程序员(互关)9 小时前
Java核心技术精要:高效实践指南
java·开发语言·性能优化
CoderYanger9 小时前
动态规划算法-子序列问题(数组中不连续的一段):28.摆动序列
java·算法·leetcode·动态规划·1024程序员节
代码栈上的思考9 小时前
深入解析Spring IoC核心与关键注解
java·后端·spring
Mai Dang9 小时前
SpringBoot4用Swagger
java