`
chencvgk
  • 浏览: 15550 次
  • 性别: Icon_minigender_1
  • 来自: 苏州
社区版块
存档分类
最新评论

桥接模式(Bridge)

 
阅读更多
场景
消息类型:普通消息、加急消息、特急消息
发送方式:站内短信、E-mail、短信


定义
将抽象部分与它的实现部分分离,使它们都可以独立的变化。

桥接模式是一种结构型模式,它主要应对的是:由于实际的需要,某个类具有两个或两个以上的维度变化,如果只是用继承将无法实现这种需要,或者使得设计变得相当臃肿。

桥接模式的做法是把变化部分抽象出来,使变化部分与主类分离开来,从而将多个维度的变化彻底分离。最后,提供一个管理类来组合不同维度上的变化,通过这种组合来满足业务的需要。

结构


模式讲解
什么是桥接
通俗点说就是在不同的东西之间搭一个桥,让它们能够连接起来。可以互相通讯和使用。
那么在桥接模式中到底是给什么东西搭桥呢?
就是为被分离的抽象部分和实现部分来搭桥。比如前面场景中在抽象的消息和具体的消息发送之间搭个桥。

独立变化
桥接模式的意图是使得抽象和实现可以独立变化,都可以分别扩充。也就是说抽象部分和实现部分是一种非常松散的关系。
从某种角度来讲,抽象部分和实现部分是可以完全分开的,独立的,抽象部分不过是一个使用实现部分对外接口的程序罢了。

动态变换功能
由于桥接模式中的抽象部分和实现部分是完全分离的,因此可以在运行是动态组合具体的真实实现,从而达到动态变换功能的目的。
从另外一个角度看,抽象部分和实现部分没有固定的绑定关系,因此同一个真实实现可以被不同的抽象对象使用。

桥接模式和继承
继承是扩展对象功能的一个常见手段,通常情况下,继承扩展的功能的变化纬度都是一维的,也就是变化的因素只有一类。
对于出现变化因素有两类的,也就是有两个变化纬度的情况,继承实现就会比较痛苦。比如开始的场景,就有两个变化纬度,一个是消息的类别,不同的消息类别处理不同;另外一个是消息的发送方式。
桥接模式就是用来解决这种有两个变化纬度的情况下,如何灵活地扩展功能的一个很好的方案。其实,桥接模式主要是把继承改成了使用对象组合,从而把两个纬度分开。

典型例子 JDBC
我们使用JDBC时,是面向JDBC的API开发程序的,这些接口就相当于桥接模式中抽象部分的接口。
那么怎样得到这些API呢?是通过DriverManager来得到的。JDBC的驱动程序实现了JDBC的API,驱动程序就相当于桥接模式中的具体实现部分。而且不同的数据库,由于数据库实现不一样,可执行的sql也不完全一样,因此对于JDBC驱动的实现也是不一样的,也就是不同的数据库会有不同的驱动实现。

那么如何JDBC的API和驱动程序是如何连接起来的呢?就是如何桥接的呢?
就是前面提到的DriverManager来把它们连接起来。DriverManager在这里起到了类似简单工厂的功能。
Connection conn=DriverManager.getConnection(......);

思考桥接模式
桥接模式的本质:分离抽象和实现

对设计原则的体现
开闭原则
多用对象组合,少用对象继承




分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics