桥接模式是什么?

桥接模式是把抽象化和实现化解耦,让两者可以独立,该设计模式属于结构性设计模式。何为将抽象化和实现化解耦,可以理解为将功能点抽象出来,功能的实现如何取决于不同的需求,但是抽象的功能点(接口)已经被桥接到原本的类型上,只用关注与实现。原本的类型变化,和抽象的功能点可以自由变化,中间的桥梁已经搭建起来了
桥接模式其实就是不单单使用类继承的方式,而是重点使用类聚合的方式,进行桥接,把抽象的功能点,聚合(注入)到基类里面。

桥接模式的好处

一般用于解决什么问题呢?
主要是功能点实现种类多,多个维度的功能点,独立变化,没有什么关联,可以按照维度来管理。比如有 2 个维度,每个维度有 3 种实现,但是不同的维度之间其实没有关联,如果按照维度之间两两关联来搞,单单是实现类的数量就已经2 3 = 6个类了,是在不太合适,还耦合在一块。
用电脑举个例子,既会分成不同的品牌,比如戴尔,联想,又会分为台式机,笔记本,那么不同的类就会很多,功能可能比较重复。正是鉴于这一点,我们得剥离重复的功能,用桥接的方式,来维护抽象出来的共同功能点。
桥接模式 - 图1
如果再新增一个品牌,比如,华硕,那么又得增加两个类,这明显不太合适,不同的类很多功能可能会重复。
桥接模式 - 图2
那么桥接模式怎么处理呢?桥接模式把两个不同的维度 台式机*笔记本
抽取出来,相当于作为一个通用的属性来维护。
桥接模式 - 图3

代码Demo演示

首先,定义一个抽象的电脑类AbstractComputer,在其中有一个属性是ComputerType,表示电脑的类型:

  1. public abstract class AbstractComputer {
  2. protected ComputerType type;
  3. public void setType(ComputerType type) {
  4. this.type = type;
  5. }
  6. public abstract void work();
  7. }

再定义三种类型的电脑:LenovoComputer,AsusComputer,DellComputer:

  1. public class LenovoComputer extends AbstractComputer{
  2. @Override
  3. public void work() {
  4. System.out.print("联想");
  5. type.feature();
  6. }
  7. }
  1. public class AsusComputer extends AbstractComputer{
  2. @Override
  3. public void work() {
  4. System.out.print("华硕");
  5. type.feature();
  6. }
  7. }
  1. public class DellComputer extends AbstractComputer{
  2. @Override
  3. public void work() {
  4. System.out.print("戴尔");
  5. type.feature();
  6. }
  7. }

电脑类型这个维度同样需要一个抽象类ComputerType,里面有一个说明功能的方法feature():

  1. public abstract class ComputerType {
  2. // 功能特性
  3. public abstract void feature();
  4. }

电脑类型这个维度,我们定义台式机和笔记本电脑两种:

  1. public class DesktopComputerType extends ComputerType{
  2. @Override
  3. public void feature() {
  4. System.out.println(" 台式机:性能强大,拓展性强");
  5. }
  6. }
  1. public class LaptopComputerType extends ComputerType{
  2. @Override
  3. public void feature() {
  4. System.out.println(" 笔记本电脑:小巧便携,办公不在话下");
  5. }
  6. }

测试一下,我们需要不同的搭配的时候,只需要将一个维度set到对象中去即可,就可以聚合出不同品牌不同类型的电脑:

  1. public class BridgeTest {
  2. public static void main(String[] args) {
  3. ComputerType desktop = new DesktopComputerType();
  4. LenovoComputer lenovoComputer = new LenovoComputer();
  5. lenovoComputer.setType(desktop);
  6. lenovoComputer.work();
  7. ComputerType laptop = new LaptopComputerType();
  8. DellComputer dellComputer = new DellComputer();
  9. dellComputer.setType(laptop);
  10. dellComputer.work();
  11. }
  12. }

总结一下

桥接模式,本质上就是将不同维度或者说功能,抽象出来,作为属性,聚合到对象里面,而不是通过继承。这样一定程度上减少了类的数量,但是如果不同的维度之间,变化是相关联的,这样使用起来还需要再做各种特殊判断,使用起来容易造成混乱,不宜使用。(重点:用组合/聚合关系代替继承关系来实现
JDBC,搞过Java的同学应该都知道,这是一种Java统一访问数据库的API,可以操作Mysql,Oracle等,主要用到的设计模式也是桥接模式,有兴趣可以了解一下Driver驱动类管理的源码

https://segmentfault.com/a/1190000041225650
https://juejin.cn/post/6998814940114976775