② 设计模式的艺术-08.桥接(Bridge)模式

为什么需要桥接(Bridge)模式

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

  采用多层继承结构:

多层继承结构代码示例

Computer.java

package com.cnki.bridge;

public interface Computer {
    void sale();
}

class Desktop implements Computer {
    @Override
    public void sale() {
        System.out.println("销售台式机!");
    }
}

class Laptop implements Computer {
    @Override
    public void sale() {
        System.out.println("销售笔记本!");
    }
}
class Pad implements Computer {
    @Override
    public void sale() {
        System.out.println("销售平板电脑!");
    }
}

class LenovoDesktop extends Desktop {
    @Override
    public void sale() {
        System.out.println("销售联想台式机");
    }
}
class LenovoLaptop extends Laptop {
    @Override
    public void sale() {
        System.out.println("销售联想笔记本");
    }
}
class LenovoPad extends Pad {
    @Override
    public void sale() {
        System.out.println("销售联想平板电脑");
    }
}



class ShenzhouDesktop extends Desktop {
    @Override
    public void sale() {
        System.out.println("销售神舟台式机");
    }
}
class ShenzhouLaptop extends Laptop {
    @Override
    public void sale() {
        System.out.println("销售神舟笔记本");
    }
}
class ShenzhouPad extends Pad {
    @Override
    public void sale() {
        System.out.println("销售神舟平板电脑");
    }
}


class DellDesktop extends Desktop {
    @Override
    public void sale() {
        System.out.println("销售戴尔台式机");
    }
}
class DellLaptop extends Laptop {
    @Override
    public void sale() {
        System.out.println("销售戴尔笔记本");
    }
}
class DellPad extends Pad {
    @Override
    public void sale() {
        System.out.println("销售戴尔平板电脑");
    }
}
View Code

采用多层继承结构带来的问题

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

  使用桥接模式,连接“电脑类型”和“电脑品牌”。

 

问题:

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

  如果增加一个新的电脑类型,则要增加各个品牌下面的类。

  如果增加一个新的品牌,也要增加各种电脑类型面的类。

  违反单一职责原则:

  一个类:联想笔记本,有两个引起这个类变化的原因。(联想是品牌,笔记本是类型,品牌类型没有分开!)

桥接模式总结

  桥接模式可以取代多层继承的方案。 多层继承违背了单一职责原则,复用性较差,类的个数也非常多。桥接模式可以极大的减少子类的个数,从而降低管理和维护的成本。

  桥接模式极大的提高了系统可扩展性,在两个变化维度中任意扩展一个维度,都不需要修改原有的系统,符合开闭原则。

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

  JDBC驱动程序

  AWT中的Peer架构

  银行日志管理:

  格式分类:操作日志、交易日志、异常日志

   距离分类:本地记录日志、异地记录日志

  人力资源系统中的奖金计算模块:

  奖金分类:个人奖金、团体奖金、激励奖金。

   部门分类:人事部门、销售部门、研发部门。

  OA系统中的消息处理:

  业务类型:普通消息、加急消息、特急消息

  发送消息方式:系统内消息、手机短信、邮件

桥接模式代码示例

Brand.java

package com.cnki.bridge;

/**
 * 电脑类型的维度
 * @author Administrator
 *
 */
public class Computer2 {
    
    protected Brand brand;//品牌
    
    public Computer2(Brand b) {
        this.brand = b;
    }
    
    public void sale(){
        brand.sale();
    }
    
}

class Desktop2 extends Computer2 {

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

class Laptop2 extends Computer2 {
    
    public Laptop2(Brand b) {
        super(b);
    }
    
    @Override
    public void sale() {
        super.sale();
        System.out.println("销售笔记本");
    }
}
View Code

Computer2.java

package com.cnki.bridge;

/**
 * 电脑类型的维度
 * @author Administrator
 *
 */
public class Computer2 {
    
    protected Brand brand;//品牌
    
    public Computer2(Brand b) {
        this.brand = b;
    }
    
    public void sale(){
        brand.sale();
    }
    
}

class Desktop2 extends Computer2 {

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

class Laptop2 extends Computer2 {
    
    public Laptop2(Brand b) {
        super(b);
    }
    
    @Override
    public void sale() {
        super.sale();
        System.out.println("销售笔记本");
    }
}
View Code

测试

package com.cnki.bridge;

public class Client {
    public static void main(String[] args) {
        //销售联想的笔记本电脑
        Computer2  c = new Laptop2(new Lenovo());
        c.sale();
        
        //销售神舟的台式机
        Computer2 c2 = new Desktop2(new Shenzhou());
        c2.sale();
        
        
    }
}
View Code

 小结

  桥接模式可以取代多重继承

  有多个变化维度可以使用桥接模式

posted @ 2018-03-22 20:35  ~沐风  阅读(228)  评论(0编辑  收藏  举报