设计模式之Bridge(转载banq)
Bridge模式定义 :
将抽象和行为划分开来,各自独立,但能动态的结合。
任何事物对象都有抽象和行为之分,例如人,人是一种抽象,人分男人和女人等;人有行为,行为也有各种具体表现,所以,“人”与“人的行为”两个概念也反映了抽象和行为之分。
在面向对象设计的基本概念中,对象这个概念实际是由属性和行为两个部分组成的,属性我们可以认为是一种静止的,是一种抽象,一般情况下,行为是包含在一个对象中,但是,在有的情况下,我们需要将这些行为也进行归类,形成一个总的行为接口,这就是桥模式的用处。
为什么使用?
不希望抽象部分和行为有一种固定的绑定关系,而是应该可以动态联系的。
如果一个抽象类或接口有多个具体实现(子类、concrete subclass),这些子类之间关系可能有以下两种情况:
1. 这多个子类之间概念是并列的,如前面举例,打桩,有两个concrete class:方形桩和圆形桩;这两个形状上的桩是并列的,没有概念上的重复。
2.这多个子类之中有内容概念上重叠.那么需要我们把抽象共同部分和行为共同部分各自独立开来,原来是准备放在一个接口里,现在需要设计两个接口:抽象接口和行为接口,分别放置抽象和行为.
例如,一杯咖啡为例,子类实现类为四个:中杯加奶、大杯加奶、 中杯不加奶、大杯不加奶。
但是,我们注意到:上面四个子类中有概念重叠,可从另外一个角度进行考虑,这四个类实际是两个角色的组合:抽象 和行为,其中抽象为:中杯和大杯;行为为:加奶 不加奶(如加橙汁 加苹果汁).
实现四个子类在抽象和行为之间发生了固定的绑定关系,如果以后动态增加加葡萄汁的行为,就必须再增加两个类:中杯加葡萄汁和大杯加葡萄汁。显然混乱,扩展性极差。
那我们从分离抽象和行为的角度,使用Bridge模式来实现。
如何实现?
以上面提到的咖啡 为例. 我们原来打算只设计一个接口(抽象类),使用Bridge模式后,我们需要将抽象和行为分开,加奶和不加奶属于行为,我们将它们抽象成一个专门的行为接口.
先看看抽象部分的接口代码:
public abstract class Coffee { CoffeeImp coffeeImp; public void setCoffeeImp() { public CoffeeImp getCoffeeImp() {return this.CoffeeImp;} public abstract void pourCoffee(); |
其中CoffeeImp 是加不加奶的行为接口,看其代码如下:
public abstract class CoffeeImp { public abstract void pourCoffeeImp(); } |
现在我们有了两个抽象类,下面我们分别对其进行继承,实现concrete class:
//中杯 public void pourCoffee() coffeeImp.pourCoffeeImp(); //大杯 public void pourCoffee() coffeeImp.pourCoffeeImp(); |
上面分别是中杯和大杯的具体实现.下面再对行为CoffeeImp进行继承:
//加奶 public void pourCoffeeImp() //不加奶 public void pourCoffeeImp() |
Bridge模式的基本框架我们已经搭好了,别忘记定义中还有一句:动态结合,我们现在可以喝到至少四种咖啡:
1.中杯加奶
2.中杯不加奶
3.大杯加奶
4.大杯不加奶
看看是如何动态结合的,在使用之前,我们做个准备工作,设计一个单态类(Singleton)用来hold当前的CoffeeImp:
public class CoffeeImpSingleton { private static CoffeeImp coffeeImp; public CoffeeImpSingleton(CoffeeImp coffeeImpIn) public static CoffeeImp getTheCoffeeImp() |
看看中杯加奶 和大杯加奶 是怎么出来的:
//拿出牛奶
CoffeeImpSingleton coffeeImpSingleton = new CoffeeImpSingleton(new MilkCoffeeImp());
//中杯加奶
MediumCoffee mediumCoffee = new MediumCoffee();
mediumCoffee.pourCoffee();
//大杯加奶
SuperSizeCoffee superSizeCoffee = new SuperSizeCoffee();
superSizeCoffee.pourCoffee();
注意: Bridge模式的执行类如CoffeeImp和Coffee是一对一的关系, 正确创建CoffeeImp是该模式的关键。
原文网址:http://www.jdon.com/designpatterns/bridge.htm
设计模式之Bridge(转载banq)相关推荐
- java 设计模式之Bridge
设计模式之Bridge Bridge定义 : 将抽象和行为划分开来,各自独立,但能动态的结合. 为什么使用? 通常,当一个抽象类或接口有多个具体实现(concrete subclass),这些conc ...
- 设计模式之——bridge模式
Bridge模式,又叫桥接模式,是针对同一接口进行扩展与实现操作的一种设计模式. 这种模式,与之前学过的适配器模式具有相似的地方,也有不同的地方,下面就让我们一一解析吧. 首先,我们要了解到,为什么需 ...
- Java设计模式---桥接Bridge模式
参考于 : 大话设计模式 马士兵设计模式视频 写在开头: 桥接模式主要用于一件事物分成了两个维度,进行排列组合,比如礼物,可以分成优雅的礼物(抽象),花(具体),排列组合优雅的花! 1.为什么使用桥接 ...
- iOS中都有什么设计模式?各个设计模式的作用 (转载)
原文地址: http://www.cnblogs.com/dxb123456/p/5479198.html 一 iOS中都有什么设计模式? 1.代理模式 2.观察者模式 3.MVC模式 4.单例模式 ...
- 设计模式笔记——Bridge
桥接模式Bridge Pattern 组合关系(实心菱形):强的拥有关系,体现了严格的整体和部分的关系,部分和整体的生命周期相同. 聚合关系(空心菱形):弱的拥有关系,A对象可以包含B对象,B对象不是 ...
- 桥接设计模式(Bridge)
Bridge??? Bridge的意思是"桥梁".就像在现实世界中,桥梁的功能是将河流的两侧连接起来一样,Bridge模式的作用也是将两样东西连接起来,它们分别是类的功能层次结构和 ...
- 设计模式--桥(Bridge)模式
模式定义 将抽象部分(业务功能)与实现部分(平台实现)分离,使它们都可以独立地变化. 类图 应用场景 在业务功能具有抽象功能和差异实现时需要独立的适应后面可能遇到的变化时使用桥接模式 优点 1.符合开 ...
- JAVA bridge设计模式,java设计模式之Bridge
Bridge定义 : 将抽象和行为划分开来,各自独立,但能动态的结合. 为什么使用? 通常,当一个抽象类或接口有多个具体实现(concrete subclass),这些concrete之间关系可能有以 ...
- 设计模式袖珍版 连续转载之 - Proxy(代理)
原作:fanix 理解并使用设计模式,能够培养我们良好的面向对象编程习惯,同时在实际应用中,可以如鱼得水,享受游刃有余的乐趣. Proxy是比较有用途的一种模式,而且变种较多,应用场合覆盖从小结构到整 ...
最新文章
- 大疆、港科大联手!双目3D目标检测实验效果大放送 | CVPR 2019
- 上海市国资大数据课题启动仪式暨数据资产技术及金融行业应用沙龙隆重开幕...
- 设置Windows XP自动登录的两种方法
- 会计科目****不能使用(请更正)
- 离开时自动提示设为首页
- 我的Android进阶之旅------Android Gusture 手势识别小案例
- 一个.NET Core开发者的Linux入门学习笔记
- weblogic创建域后启动不了_摩托车淋雨后启动不了什么原因?如何解决?
- Redis入门指南(第2版) Redis设计思路学习与总结
- 拳王虚拟项目公社:自动化的虚拟资源产品,唱歌教程赚地盆满钵满
- H264所采用的指数格伦布熵编码算法原理及应用
- WEB HTTP:浏览器HTTP协议漫谈、请求对象Httprequest、响应对象HttpResponse、浏览器内部工作原理(待完善)
- 3 月书讯丨如果我早点看到这套书,数学也不会学成这个鬼样子
- java 输入输出_java基本输入输出小结
- Python中Oracle的连接、增删改查
- 同余定理+前缀和解题技巧
- linux下安装ab压力测试工具及ab命令详解
- 深度有趣 | 16 令人拍案叫绝的WGAN
- 基于Java+SQLServer2017实现(Web)酒店客房管理系统【100010327】
- html按住语音如何看前面内容,单音语音内容.html