Day45-设计模式-桥接模式


title: Day45-设计模式-桥接模式
date: 2021-03-16 10:45:30
author: Liu_zimo


设计模式

  • 设计模式分为三种类型,共23种
    1. 创建型模式:单例模式、抽象工厂模式、原型模式、建造者模式、工厂模式
    2. 结构型模式:适配器模式、桥接模式、装饰模式、组合模式、外观模式、享元模式、代理模式
    3. 行为型模式:模版方法模式、命令模式、访问者模式、迭代器模式、观察者模式、中介者模式、备忘录模式、解释器模式(Interpreter模式)、状态模式、策略模式、职责链模式(责任链模式)。

桥接模式

  • 手机操作问题
    • 现在对不同手机类型的不同品牌实现操作编程(比如:开机、关机、上网,打电话等),如图:

手机问题

  • 传统方案解决手机问题(类图)
    1. 扩展性问题(类爆炸),如果我们再增加手机的样式(旋转式),就需要增加各个品牌手机的类,同样如果我们增加一个手机品牌,也要在各个手机样式类下增加
    2. 违反了单一职责原则,当我们增加手机样式时,要同时增加所有品牌的手机,这样增加了代码维护成本
    3. 解决方案 - 使用桥接模式

传统方式类图

基本介绍

  1. 桥接模式(Bridge模式)是指:将实现与抽象放在两个不同的类层次中,使两个层次可以独立改变。
  2. 是一种结构型设计模式
  3. Bridge模式基于类的最小设计原则,通过使用封装、聚合及继承等行为让不同的类承担不同的职责。它的主要特点是把抽象(Abstraction)与行为实现
    (Implementation)分离开来,从而可以保持各部分的独立性以及应对他们的功能扩展
  • 桥接模式原理类图
    1. Client类:桥接模式的调用者
    2. 抽象类(Abstraction):维护了Implementor / 即他的实现类ConcreteImplementorA…,二者是聚合关系,Abstraction充当桥接类
    3. RefinedAbstraction:是Abstraction抽象类的子类
    4. Implementor:行为实现类的接口
    5. ConcreteImplementorA/B:行为的具体实现类
    6. 从UML类图:这里的抽象类和接口是聚合的关系,其实调用和被调用关系

桥接模式原理类图

  • 手机问题 - 桥接UML类图实现

手机问题UML

package com.zimo.设计模式.桥接模式;
/**
 * 设计模式 - 桥接模式:手机问题
 *      品牌接口
 *
 * @author Liu_zimo
 * @version v0.1 by 2021/3/16 11:34
 */
public interface Brand {
    
    
    void open();
    void close();
    void call();
}
------------------------------------------------------------
package com.zimo.设计模式.桥接模式;
/**
 * 设计模式 - 桥接模式:手机问题
 *      小米手机实现
 *
 * @author Liu_zimo
 * @version v0.1 by 2021/3/16 11:36
 */
public class XiaoMi implements Brand {
    
    
    @Override
    public void open() {
    
     System.out.println("小米手机开机"); }
    @Override
    public void close() {
    
     System.out.println("小米手机关机"); }
    @Override
    public void call() {
    
     System.out.println("小米手机打电话"); }
}
------------------------------------------------------------
package com.zimo.设计模式.桥接模式;
/**
 * 设计模式 - 桥接模式:手机问题
 *      vivo手机实现
 *
 * @author Liu_zimo
 * @version v0.1 by 2021/3/16 11:40
 */
public class Vivo implements Brand {
    
    
    @Override
    public void open() {
    
     System.out.println("vivo手机开机"); }
    @Override
    public void close() {
    
     System.out.println("vivo手机关机"); }
    @Override
    public void call() {
    
     System.out.println("vivo手机打电话"); }
}
------------------------------------------------------------
package com.zimo.设计模式.桥接模式;
/**
 * 设计模式 - 桥接模式:手机问题
 *      抽象手机类
 *
 * @author Liu_zimo
 * @version v0.1 by 2021/3/16 11:41
 */
public abstract class Phone {
    
    
    // 组合品牌
    private Brand brand;
    public Phone(Brand brand) {
    
     this.brand = brand; }
    protected void open(){
    
     this.brand.open(); }
    protected void close() {
    
     this.brand.close(); }
    protected void call() {
    
     this.brand.call(); }
}
------------------------------------------------------------
package com.zimo.设计模式.桥接模式;
/**
 * 设计模式 - 桥接模式:手机问题
 *      手机样式 - 折叠式
 *
 * @author Liu_zimo
 * @version v0.1 by 2021/3/16 11:44
 */
public class Folded extends Phone {
    
    
    public Folded(Brand brand) {
    
     super(brand); }
    public void open(){
    
    
        System.out.println("折叠式");
        super.open();
    }
    public void close(){
    
    
        System.out.println("折叠式");
        super.close();
    }
    public void call(){
    
    
        System.out.println("折叠式");
        super.call();
    }

    public static void main(String[] args) {
    
    
        Phone phone = new Folded(new XiaoMi());
        phone.open();
        phone.call();
        phone.close();
    }
}
------------------------------------------------------------
package com.zimo.设计模式.桥接模式;
/**
 * 设计模式 - 桥接模式:手机问题
 *      手机样式 - 直立式
 *
 * @author Liu_zimo
 * @version v0.1 by 2021/3/16 11:50
 */
public class UpRight extends Phone{
    
    
    public UpRight(Brand brand) {
    
     super(brand); }
    public void open(){
    
    
        System.out.println("直立式");
        super.open();
    }
    public void close(){
    
    
        System.out.println("直立式");
        super.close();
    }
    public void call(){
    
    
        System.out.println("直立式");
        super.call();
    }

    public static void main(String[] args) {
    
    
        Phone phone = new UpRight(new Vivo());
        phone.open();
        phone.call();
        phone.close();
    }
}

桥接模式在JDBC源码中的应用

  • Jdbc的Driver接口,如果从桥接模式来看,Driver就是一个接口,下面可以有MySQL的Driver,Oracle的Driver,这些就可以当做实现接口类

注意实现和细节

  1. 实现了抽象和实现部分的分离,从而极大的提供了系统的灵活性,让抽象部分和实现部分独立开来,这有助于系统进往分层设计,从而产生更好的结构化系统。
  2. 对于系统的高层部分,只需要知道抽象部分和实现部分的接口就可以了,其它的部分由具体业务来完成。
  3. 桥接模式替代多层继承方案,可以减少子类的个数,降低系统的管理和维护成本。
  4. 桥接模式的引入增加了系统的理解和设计难度,由于聚合关联关系建立在抽象层,要求开发者针对抽象进行设计和编程
  5. 桥接模式要求正确识别出系统中两个独立变化的维度,因此其使用范围有一定的局限性,即需要有这样的应用场景。

应用场景

  1. 对于那些不希望使用继承或因为多层次继承导致系统类的个数急剧增加的系统,桥接模式尤为适用
  2. 常见的应用场景
    • JDBC驱动程序
    • 银行转账系统
      • 转账分类:网上转账,柜台转账,AMT专账
      • 转账用户类型:普通用户,银卡用户,金卡用户…
    • 消息管理
      • 消息类型:即时消息,延时消息
      • 消息分类:手机短信,邮件消息,QQ消息…

猜你喜欢

转载自blog.csdn.net/qq_38205875/article/details/114879366