为什么需要桥接(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("销售戴尔平板电脑");
}
}
采用多层继承结构带来的问题
这个场景中有两个变化的维度:电脑类型、电脑品牌
使用桥接模式,连接“电脑类型”和“电脑品牌”。
问题:
扩展问题(类个数膨胀问题)
如果增加一个新的电脑类型,则要增加各个品牌下面的类。
如果增加一个新的品牌,也要增加各种电脑类型面的类。
违反单一职责原则:
一个类:联想笔记本,有两个引起这个类变化的原因。(联想是品牌,笔记本是类型,品牌类型没有分开!)
桥接模式总结
桥接模式可以取代多层继承的方案。 多层继承违背了单一职责原则,复用性较差,类的个数也非常多。桥接模式可以极大的减少子类的个数,从而降低管理和维护的成本。
桥接模式极大的提高了系统可扩展性,在两个变化维度中任意扩展一个维度,都不需要修改原有的系统,符合开闭原则。
桥接模式实际开发中应用场景
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("销售笔记本");
}
}
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("销售笔记本");
}
}
测试
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(); }
}
小结
桥接模式可以取代多重继承
有多个变化维度可以使用桥接模式