【设计模式】结构型模式 - 桥接模式

桥接模式是一种设计模式,它将抽象部分与实现部分分离,使得两者可以独立发展。这种模式降低了抽象和实现之间的耦合,遵循了开闭原则,适合于有两个独立变化维度的系统。通过组合而非继承实现,桥接模式提高了代码的灵活性和可维护性。在实际应用中,当需要替换继承关系以减少侵入性和臃肿的子类时,可以考虑使用桥接模式。
摘要由CSDN通过智能技术生成

桥接模式

定义

将抽象与实现分离,使它们可以独立变化。它是用组合关系代替继承关系来实现,从而降低了抽象和实现这两个可变维度的耦合度。
桥接模式遵循了里氏替换原则和依赖倒置原则,最终实现了开闭原则,对修改关闭,对扩展开放。

特点

优点
  • 抽象与实现分离,扩展能力强;
  • 符合开闭原则;
  • 符合合成复用原则;
  • 其实现细节对客户透明。
缺点

由于聚合关系建立在抽象层,要求开发者针对抽象化进行设计与编程,能正确地识别出系统中两个独立变化的维度,这增加了系统的理解和设计难度。

结构与实现

结构

主要角色:

  • 抽象化角色:定义抽象类,并包含一个对实现化对象的引用;
  • 扩展抽象化角色: 是抽象化角色的子类,实现父类中的业务方法,并通过组合关系调用实现化角色中的业务方法;
  • 实现化角色:定义实现化角色的接口,供扩展抽象化角色调用;
  • 具体实现化角色,给出实现化角色接口的具体实现。

类图:
类图结构

实现
  • 实现化角色
interface Implementor {
	void operationImpl();
}
  • 具体实现化角色
class ConcreteImplementorA implements Implementor {
	public void operationImpl() {
		// A 类的具体实现类代码逻辑
	}
}
  • 抽象化角色
abstract class Abstraction {
	protected Implementor imple;
	
	protected Abstraction(Implementor imple) {
		this.imple = imple;
	}

	public abstract void operation();
}
  • 扩展抽象化角色
class RefinedAbstraction extends Abstraction {
	protected RefinedAbstraction(Implementor imple) {
		super(imple);
	}
	public void operation() {
		// 扩展抽象化角色被访问
	}
}
  • 调用客户端
public class BridgeTest {
	public static void main(String[] args) {
		Implementor imple = new ConcreteImplementorA();
		Abstraction abs = new RefinedAbstraction(imple);
		abs.operation();
	}
}

应用场景

桥接模式通常适用于以下场景。

  1. 当一个类存在两个独立变化的维度,且这两个维度都需要进行扩展时;
  2. 当一个系统不希望使用继承或因为多层次继承导致系统类的个数急剧增加时;
  3. 当一个系统需要在构件的抽象化角色和具体化角色之间增加更多的灵活性时。

桥接模式的一个常见使用场景就是替换继承。继承有一个缺点:具有强侵入性,同时会导致子类臃肿,因此,在设计模式中,优先使用组合/聚合,而不是继承

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值