大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。
Abstraction:抽象部分的父类,定义须要实现的接口。
维护对实现部分的引用,从而把实现桥接到Implementor中去
Implementor:实现部分的接口
RefinedAbstraction:扩展抽象部分的接口
ConcreteImplementorA/B:真正实现Implementor接口的对象
//桥接模式定义:将抽象部分与它的实现部分分离,使得他们都能够独立地变化。抽象部分仅仅定义出须要实现什么方法(非抽象方法),相当于仅仅给出一个方法的接口,接口中去调用桥接过来的详细实现类去实现,从而实现灵活的扩展性 //广义来讲,桥接模式很普遍,面向抽象编程,面向接口编程就能够看作是他的体现 //实例:一个系统,要依照不同的要求发信息(普通。加急,特急),并且还要以不同的方式发送(站内信,Email,短信)等,考虑到其扩展性,用桥接模式再合适只是了 //上代码 //桥接的一半---抽象部分 public abstract class AbstractionMessage { protected MessageImplementor impl; public AbstractMessage(MessageImplementor impl) { this.impl = impl; } public void sendMessage(String message, String toUser) { this.impl.send(message, toUser); } } //发送消息的统一接口。即桥接的还有一半---实现的接口 public interface MessageImplementor { public void send(String message, String toUser); } //桥接的还有一半---实现 public class MessageSMS implements MessageImplementor { public void send(String message,String toUser) { System.out.println("使用站内信方式。发送消息'"+message+"'给"+toUser); } } //桥接的还有一半---实现 public class MessageEmail implements MessageImplementor { public void send(String message,String toUser) { System.out.println("使用邮件方式,发送消息'"+message+"'给"+toUser); } } //普通消息 public class CommonMessage extends AbstractionMessage { public CommonMessage(MessageImplementor impl) { super(impl); } public void sendMessage(String message, String toUser) { super.sendMessage(message, toUser); } } //加急消息 public class UrgencyMessage extends AbstractionMessage { public UrgencyMessage(MessageImplementor impl) { super(impl); } public void sendMessage(String message, String toUser) { super.sendMessage(message, toUser); } public Object watch(String messageId) { return null;//获取对应的数据。组织成监控的对象。然后返回 } } //client測试类 public class Client { public static void main(String[] args) { MessageImplementor impl = new MessageSMS(); AbstractionMessage m = new CommonMessage(impl); m.sendMessage("測试", "小李"); MessageImplementor impl2 = new MessageEmail(); AbstractionMessage m2 = new UrgencyMesssage(impl2); m2.sendMessage("測试", "小李"); } } //从client的调用能够看出来。无论是要添加消息类型还是发送消息的方式,全然是件很easy的事情。由于没有耦合,扩展起来很轻松。 //关于谁来桥接 //1.由抽象部分的对象自己来创建对应的Implementor对象。依据參数推断详细创建哪个 //2.在Abstraction中创建默认的Implementor对象,假设须要,让子类来改动 //3.使用抽象工厂或简单工厂 //4.使用IoC/DI方式 //Java中的JDBC就是很典型的桥接应用 //桥接模式的本质:分离抽象和实现 //桥接模式很好地提现了开闭原则OCP //长处: //1.分离抽象和实现部分 //2.更好的扩展性 //3.可动态地切换实现 //4.降低子类的个数 //使用桥接模式的场景 //1.假设你不希望在抽象部分和实现部分採用固定的绑定关系,能够採用桥接模式 //2.假设出现抽象部分和实现部分都能够扩展的情况,能够採用桥接模式 //3.假设希望实现部分的改动不会对客户产生影响。能够採用桥接模式 //4.假设採在实现继承。它会导致许多子类,对于这样的情况,还拿桥接模式
版权声明:本文博客原创文章。博客,未经同意,不得转载。
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/117678.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...