Bridge模式就是将类的功能层次结构和类的实现层次结构连接起来。

  类的功能层次结构就是根据实际非抽象类来说的,也就是父类具有基本功能,然后在子类中增加新功能。用于增加新功能。

  类的实现层次结构就是根据抽象类来说的,也就是父类通过声明抽象方法来定义接口,子类通过实现具体方法来实现接口。用于增加新实现。

 package bigjunoba.bjtu.function;

 import bigjunoba.bjtu.implement.DisplatImpl;

 public class Display {

     private DisplatImpl impl;

     public Display(DisplatImpl impl) {
this.impl = impl;
} public void open() {
impl.rawOpen();
} public void pring() {
impl.rawPrint();
} public void close() {
impl.rawClose();
} public final void display() {
open();
pring();
close();
}
}

  Display类位于“类的功能层次结构”的最上层。这里的原理和Builder模式比较一下还是有点相似的。DisplatImpl类是个抽象类,定义了三个抽象方法。同样的Display类通过构造函数将DisplatImpl类传递进来,由于抽象类不能被实例化,因此传递进来的也就是DisplatImpl的子类,并保存在impl字段中。impl字段就是类的两个层次结构的“桥梁”。

 package bigjunoba.bjtu.function;

 import bigjunoba.bjtu.implement.DisplatImpl;

 public class CountDisplay extends Display{

     public CountDisplay(DisplatImpl impl) {
super(impl);
} public void multiDisplay(int times) {
open();
for (int i = 0; i < times; i++) {
pring();
}
close();
} }

  CountDisplay类位于“类的功能层次结构”的最下层。CountDisplay类继承了Display类,用于在Display类的基础上增加一个新功能。首先通过构造器调用父类的构造函数,然后multiDisplay方法用来增加新的功能。

  下面来看一下“类的实现层次结构”部分。也就是桥的另外一侧。

 package bigjunoba.bjtu.implement;

 public abstract class DisplatImpl {

     public abstract void rawOpen();
public abstract void rawPrint();
public abstract void rawClose(); }

   DisplatImpl位于“类的实现层次结构”的最上层。声明了三个抽象方法。

 package bigjunoba.bjtu.implement;

 public class StringDisplayImpl extends DisplatImpl{

     private String string;
private int width;
public StringDisplayImpl(String string) {
this.string = string;
this.width = string.getBytes().length;
} @Override
public void rawOpen() {
printLine();
} @Override
public void rawPrint() {
System.out.println("|" + string + "|");
} @Override
public void rawClose() {
printLine();
} private void printLine() {
System.out.print("+");
for (int i = 0; i < width; i++) {
System.out.print("-");
}
System.out.println("+");
} }

  StringDisplayImpl类位于“类的实现层次结构”的最下层。作为DisplatImpl类的子类,用来实现DisplatImpl类的三个抽象方法。

 package bigjunoba.bjtu.test;

 import bigjunoba.bjtu.function.CountDisplay;
import bigjunoba.bjtu.function.Display;
import bigjunoba.bjtu.implement.StringDisplayImpl; public class Main { public static void main(String[] args) {
Display display1 = new Display(new StringDisplayImpl("Lianjiang"));
Display display2 = new CountDisplay(new StringDisplayImpl("Lianjiangjiang"));
CountDisplay countDisplay = new CountDisplay(new StringDisplayImpl("Lianjiangjiangjiang"));
display1.display();
display2.display();
countDisplay.display();
countDisplay.multiDisplay(5);
}
}

  Main类作为测试类,这里需要好好理解一下。这三个实例的创建都是先向StringDisplayImpl类传递一个String类型的字符串,然后通过StringDisplayImpl类的构造器生成的对应的三个实例。display1字段保存的是Display类的构造器通过接受DisplayImpl抽象类的子类生成的实例也就是impl,然后生成了Display类的实例。display2字段保存的是具有新功能的Display类的实例。而countDisplay字段保存的也是具有新功能的CountDisplay类的实例,由于CountDisplay类是Display类的子类,本质上来说还是属于Display类的实例,说白了就是既可以调用Display类的基本功能,也可以调用CountDisplay类的新功能。

+---------+
|Lianjiang|
+---------+
+--------------+
|Lianjiangjiang|
+--------------+
+-------------------+
|Lianjiangjiangjiang|
+-------------------+
+-------------------+
|Lianjiangjiangjiang|
|Lianjiangjiangjiang|
|Lianjiangjiangjiang|
|Lianjiangjiangjiang|
|Lianjiangjiangjiang|
+-------------------+

  输出结果是这样的。结合上述分析来看就很明显了。

  下面是Bridge模式的类图。

  这里就不解释了。结合示例程序看就很容易理解。要强调的一点是,如果想要增加功能,只需要在“类的功能层次结构”一侧增加类即可,而“类的实现层次结构”不需要做任何改变,最关键的是,增加后的功能可以被“所有的实现”使用。

  扩展部分:继承和委托。

  继承是一种强关联关系。通俗来说,就是如果不修改代码,那么就很难改变子类和父类之间的关系。

  委托是一种弱关联关系。例如,示例中,Display类的impl字段保存了实现的实例,这样类的任务就发生了转移,比如调用open方法就会调用impl.rawOpen方法,也就是如果想让Display类工作,这个时候Display类就不自己工作,而是交给impl,让impl去工作。这就是“委托”。更加深入地理解,弱关联是因为,只有Display类的实例生成时,才与作为参数被传入的类构成关联。示例中的Main类,只有生成DIsplay类和CountDisplay类的实例时,才将StringDisplayImpl的实例作为参数传递给Display类和CountDisplay类。还有一个优点就是,如果新加了一个实现,就是讲其他ConcreteImplementor类的实例传递给Display类和CountDisplay类时也可以轻松实现,而其他Display类和DisplayImpl类不需要做任何改变,也就是上面强调的,如果想要增加功能,只需要在“类的功能层次结构”一侧增加类即可,而“类的实现层次结构”不需要做任何改变,最关键的是,增加后的功能可以被“所有的实现”使用。总结来说,这种模式的优点就是,有利于独立地对它们进行扩展。

设计模式(九)Bridge模式的更多相关文章

  1. 【设计模式】Bridge模式(桥接模式)

    最近的一次面试中,被问到桥接模式,以前呢并没有很仔细的研究过这个设计模式,借此机会剖析一下. 先给出自己对这个模式理解后的源码: interface A{ void methodA(); } inte ...

  2. 设计模式之——bridge模式

    Bridge模式,又叫桥接模式,是针对同一接口进行扩展与实现操作的一种设计模式. 这种模式,与之前学过的适配器模式具有相似的地方,也有不同的地方,下面就让我们一一解析吧. 首先,我们要了解到,为什么需 ...

  3. Java设计模式---桥接Bridge模式

    参考于 : 大话设计模式 马士兵设计模式视频 写在开头: 桥接模式主要用于一件事物分成了两个维度,进行排列组合,比如礼物,可以分成优雅的礼物(抽象),花(具体),排列组合优雅的花! 1.为什么使用桥接 ...

  4. 设计模式--桥接(Bridge)模式

    1.概述: 桥接模式:把抽象和行为分离开来,中间需要某个介质来连接抽象化和行为化.此模式的概述听起来非常像适配器模式,不要搞混了,虽然都是借用中间介质,但意义不同.最典型的桥接模式就是:JDBC.通过 ...

  5. 设计模式:bridge模式

    目的:将“类的功能层次结构”和“类的实现层次结构”分类 类的功能层次:通过类的继承添加功能(添加普通函数) 类的实现层次:通过类的继承实现虚函数 理解:和适配器模式中的桥接方法相同 例子: class ...

  6. java面试题之----jdbc中使用的设计模式(桥接模式)

    1.JDBC(JavaDatabase Connectivity) JDBC是以统一方式访问数据库的API. 它提供了独立于平台的数据库访问,也就是说,有了JDBC API,我们就不必为访问Oracl ...

  7. [设计模式] 7 桥接模式 bridge

    #include<iostream> using namespace std; class AbstractionImp { public: virtual ~AbstractionImp ...

  8. 设计模式 ( 十九 ) 模板方法模式Template method(类行为型)

      设计模式 ( 十九 ) 模板方法模式Template method(类行为型) 1.概述 在面向对象开发过程中,通常我们会遇到这样的一个问题:我们知道一个算法所需的关键步骤,并确定了这些步骤的执行 ...

  9. 乐在其中设计模式(C#) - 桥接模式(Bridge Pattern)

    原文:乐在其中设计模式(C#) - 桥接模式(Bridge Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 桥接模式(Bridge Pattern) 作者:webabcd 介绍 ...

随机推荐

  1. Educational Codeforces Round 72 (Rated for Div. 2)

    https://www.cnblogs.com/31415926535x/p/11601964.html 这场只做了前四道,,感觉学到的东西也很多,,最后两道数据结构的题没有补... A. Creat ...

  2. 视频监控安防平台-GB28181-2016版-移动位置订阅

    视频监控安防平台-GB28181-2016版-移动位置订阅 郑重声明: 本位来自 CSDN博主「沉睡的思绪」,查看原文,请点击下面链接,原文链接:https://blog.csdn.net/songx ...

  3. Python攻破淘宝网各类反爬手段,采集淘宝网ZDB(女用)的销量!

    声明: 由于某些原因,我这里会用手机代替,其实是一样的! 环境: windows python3.6.5 模块: time selenium re 环境与模块介绍完毕后,就可以来实行我们的操作了. 第 ...

  4. ArchLinux安(重)装指南

    说实话,我其实是不想要出这篇博客的.在我这一个月安装Arch的过程中,让我感触比较深的一点是: 没有谁比这个系统的官方更懂它. 尤其是这种比较复杂的系统,更是如此. 这几天,我经历了一次重装,系统坏了 ...

  5. mybatis - 通用mapper

    title: 玩转spring-boot-mybatis date: 2019-03-11 19:36:57 type: "mybatis" categories: mybatis ...

  6. mysql操作遇到的坑(第二版)

    1.通过条件查询出上一条与下一条 sql说明:本表关联本表,然后通过其中一个表,查询出对应的条件,再用另外一个表求出上一条与下一条的数据,求出来的数据是多条的 SELECT ua.id, ua.wx_ ...

  7. 整理基础的CentOS常用命令

    如何知道apache装在哪里? which httpd 1.查看系统使用端口并释放端口 [root@my_nn_01 WEB-INF]# lsof -w -n -i tcp:80 COMMAND    ...

  8. latex转word公式 java (latextoword,latex_word,latex2word,latex_omml)

    latex_word 主要目的:     给大家分享一个我的原创作品:latex转为word公式(omml)工具 [java] 此工具主要用于将含有latex公式的文本下载成word时,将latex转 ...

  9. linux下修改python版本号

    修改python版本 1.查看已安装版本: /home/user$ whereis python 2.在其 home 目录下创建一个 alias(别名) user@ubuntu:/home/user$ ...

  10. 整理一些大厂的开源平台及github,向他们看齐...

    有人苦恼,该如何突破技术的局限性... 有人羡慕,技术上你怎么懂得这么多... 有人哀叹,唉,我已经学不动了... 我的总结(纯属个人想法):身处IT,就得不断学习和积累,才不会被狠狠地甩在身后.什么 ...