桥接模式(bridge)

 

桥接模式用于把抽象化与现实化解耦,使得二者可以独立变化。这种类型的设计模式属于结构型模式,它通过提供抽象化和实现化之间的桥接结构,来实现二者的解耦。

抽象化:其概念是将复杂物体的一个或几个特性抽出去,只需要注意其他特性的行动或过程。在面向对象就是将对象共同的性质抽取出去而形成类的过程。

实现化:针对抽象化给出的具体实现。它和抽象化是一个互逆的过程,实现化是对抽象化食物的进一步具体化。

解耦:解耦就是将抽象化和实现化之间的耦合解脱开,或者说是将它们之间的强关联转化成弱关联,将两个角色之间的继承关系改为关联关系。

主要是实现系统可以有多个角度分类,每一种角度都可能变化,那么把这种多角度分类给分离出来让他们独立变化,减少他们之间的耦合。

 

桥接模式核心要点:处理多层继承结构,处理多维度变化的场景,将各个维度设计成独立的继承结构,使各个维度可以独立的扩展在抽象层建立关联。

 

我们可以用多层继承结构实现下图的关系。

 

java pom模块之间解耦 java解耦是什么意思_System

 

问题:扩展性问题(类个数膨胀问题)

  • 如果要增加一个新的电脑类型:智能手机,则要增加各个品牌下面的类。
  • 如果要增加一个新的品牌,也要增加各种电脑类型的类。

违反单一职责原则:一个类,由两个引起这个类变化的原因

场景:商城系统中常见的商品分类,以电脑为类,如何良好的处理商品分类销售的问题?

这个场景中有两个变化的维度:电脑类型、电脑品牌。

java pom模块之间解耦 java解耦是什么意思_System_02

将上面电脑的案例分为两种维度:品牌维度和类型维度

品牌维度

package com.kevin.结构型模式.桥接模式.bridge;

/**
 * @author kevin
 * @version 1.0
 * @description     品牌维度
 * @createDate 2019/2/26
 */
public interface Brand {

    void sale();
}

class Lenovo implements Brand{

    @Override
    public void sale() {
        System.out.println("销售联想电脑");
    }
}

class Dell implements Brand{

    @Override
    public void sale() {
        System.out.println("销售戴尔电脑");
    }
}

class Hasee implements Brand{

    @Override
    public void sale() {
        System.out.println("销售神舟电脑");
    }
}

电脑维度

package com.kevin.结构型模式.桥接模式.bridge;

/**
 * @author kevin
 * @version 1.0
 * @description     桥接模式,电脑维度
 * @createDate 2019/2/26
 */
public class Computer2 {

    protected Brand brand;

    public Computer2(Brand brand) {
        this.brand = brand;
    }

    public void sale(){
        brand.sale();
    }
}

class Desktop2 extends Computer2 {

    public Desktop2(Brand brand) {
        super(brand);
    }

    @Override
    public void sale() {
        super.sale();
        System.out.println("销售台式机");
    }
}

class Laptop2 extends Computer2 {

    public Laptop2(Brand brand) {
        super(brand);
    }

    @Override
    public void sale() {
        super.sale();
        System.out.println("销售笔记本");
    }
}

class Pad2 extends Computer2 {

    public Pad2(Brand brand) {
        super(brand);
    }

    @Override
    public void sale() {
        super.sale();
        System.out.println("销售平板电脑");
    }
}

测试桥接模式

package com.kevin.结构型模式.桥接模式.bridge;

/**
 * @author kevin
 * @version 1.0
 * @description     测试桥接模式
 * @createDate 2019/1/18
 */
public class Test {

    public static void main(String[] args) {

        // 销售联想的笔记本电脑
        Computer2 c = new Laptop2(new Lenovo());
        c.sale();

        // 新增不同的品牌时,只需要到Brand接口中新增即可
        Computer2 c2 = new Desktop2(new Hasee());
        c2.sale();

    }
}

桥接模式UML类图

java pom模块之间解耦 java解耦是什么意思_java pom模块之间解耦_03

 

桥接模式总结:

  • 桥接模式可以取代多层继承的方案。多层继承违背了单一职责原则,复用性较差,类的个数也非常多。桥接模式可以极大的减少子类的个数,从而降低管理和维护的成本。
  • 桥接模式极大的提高了系统可扩展性,在两个变化维度中任意扩展一个维度,都不需要修改原有的系统,符合开闭原则。

 

桥接模式实际开发中应用场景

 

  1. JDBC驱动程序
  2. AWT中的Peer架构
  3. 银行日志管理:
  4. 格式分类:操作日志、交易日志、异常日志
  5. 距离分类:本地记录日志、异地记录日志
  6. 人力资源系统中的奖金计算模块:
  7. 奖金分类:个人奖金、团体奖金、激励奖金。
  8. 部门分类:人事部门、销售部门、研发部门。
  9. OA系统中的消息处理:
  10. 业务类型:普通消息、加急消息、特急消息
  11. 发送消息方式:系统内消息、手机短信、邮件