桥接模式

桥接模式就是将抽象部分与它的实现部分分离,使它们都可以独立地变化

Abstraction:抽象部分的接口。通常在这个抽象里面,要维护一个实现部分的对象引用,在抽象对象里面的方法,需要调用实现部分的对象来完成。这个对象里面的方法,通常都是跟具体的业务相关的方法。

RefinedAbstraction:扩展抽象部分的接口,通常在这些对象里面,定义跟实际业务相关的方法,这些方法的实现通常会使用Abstraction中定义的方法,也可能需要调用实现部分的对象来完成。

Implementor:定义实现部分的接口,这个接口不用和Abstraction里面的方法一致,通常是由Implementor接口提供基本的操作,而Abstraction里面定义的是基于这些基本操作的业务方法,也就是说Abstraction定义了基于这些基本操作的较高层次的操作。

ConcreImplementor:真正实现Implementor接口的对象。

体会桥接模式
发送提示信息:考虑这样一个实际的业务功能:发送提示消息。基本所有带业务流程处理的系统都会有这样的功能,比如某人有新的工作了,需要发送一条消息提示他。

从业务上看,消息分为普通消息,加急消息和特急消息多种,不同的消息类型,业务功能处理时不一样的,比如加急消息时在消息上添加加急,而特急消息除了添加特急外,还会做一条催促的记录,多久不完成会继续催促。从发送消息的手段上看,又有系统内短消息、手机短消息、邮件等等。

出现问题的根本原因,就在于消息的抽象和实现是混杂在一起的,这就导致了,一个纬度的变化,会引起另一个纬度进行相应的变化,从而使得程序扩展起来非常困难。

桥接模式通过引入实现的接口,把实现部分从系统中分离出去;那么,抽象这边如何使用具体的实现呢?肯定是面向实现的接口来编程了,为了让抽象这边能够很方便的与实现结合起来,把顶层的抽象接口改成抽象类,在里面持有一个具体的实现部分的实例。

这样一来,对于需要发送消息的客户端而言,就只需要创建相应的消息对象,然后调用这个消息对象的方法就可以了,这个消息对象会调用持有的真正的消息发送方式来把消息发送出去。也就是说客户端只是想要发送消息而已,并不想关系具体如何发送。

首要任务是把抽象部分和实现部分分离出来,分析要实现的功能,抽象部分就是各个消息的类型所对应的功能,而实现部分就是各种发送消息的方式。

1:从简单功能开始

从相对简单的功能开始,先实现普通消息和加急消息的功能,发送方式先实现站内短消息和Email着两种。

 

posted @ 2018-08-18 03:06  hotMemo  阅读(142)  评论(0编辑  收藏  举报