Java设计模式 _结构型模式_桥接模式

2024-04-29 09:52

本文主要是介绍Java设计模式 _结构型模式_桥接模式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、桥接模式

1、桥接模式
桥接模式(Bridge Pattern)是一种结构型设计模式。用于把一个类中多个维度的抽象化与实现化解耦,使得二者可以独立变化。

2、实现思路
使用桥接模式,一定要找到这个类中两个变化的维度:如支付功能中(平台类型,支付方式)或带颜色形状(形状,涂色)。
(1)、定义次维度规划抽象和实例方式(支付方式为抽象(接口),密码支付,扫脸支付,指纹支付为三种实例(接口实现类))。
(2)、次维度接口定义规范方法,每一种实现类遵循规范进行各自业务的实现。
(3)、定义主维度抽象类和实现类(支付渠道(抽象类),微信,支付宝(抽象类的实现类))
(4)、在主维度抽象类中,定义次维度的抽象属性,通过构造方法实例化该属性,定义统一的抽象方法(支付方法);
(5)、在主维度实现类中,通过自身方法和次维度属性的实现方法封装各自具体的业务方法。

二、代码示例

1、不使用桥接,直接判断

  // 定义和实现支付方法public static String doPay(String payUser,String receiveUser,double money, String payType,String securityMode){StringBuilder builder = new StringBuilder("");builder.append(payUser);if ("wechat".equals(payType)){builder.append("使用微信-");if ("password".equals(securityMode)){builder.append("密码支付");} else if("face".equals(securityMode)){builder.append("扫脸支付");}else if("fingerprint".equals(securityMode)){builder.append("指纹支付");}builder.append(money).append("元");}if ("alipay".equals(payType)){builder.append("使用支付宝-");if ("password".equals(securityMode)){builder.append("密码支付");} else if("face".equals(securityMode)){builder.append("扫脸支付");}else if("fingerprint".equals(securityMode)){builder.append("指纹支付");}builder.append(money).append("元");}builder.append("给").append(receiveUser);return builder.toString();}// 测试public static void main(String[] args) {System.out.println("直接方式");String directResult = doPay("张三", "李四", 30, "wechat", "password");System.out.println(directResult);directResult = doPay("张三", "王五", 10.6, "alipay", "fingerprint");System.out.println(directResult);}

运行结果:
在这里插入图片描述
说明:上面的示例中,虽然运行得到了正确的结果。但是从代码上看,所有的代码都写到一起,不利于代码管理和阅读;如果扩展支付方式或者支付平台,必然会影响彼此(如:扩展支付类型扫码支付,支付平台的微信和支付宝实现中都需要改造代码;再如:扩展支付平台中行支付,支付方式每一种都需要在新平台的方法中重写一遍),可以看出两个维度是强耦合关系,不符合设计模式的开闭原则。

2、桥接模式示例

// 支付类型接口--次维度抽象规范接口
public interface PayMode {String securityPay();
}
// 密码支付--次维度规范实现类1
public class PasswordMode implements PayMode {@Overridepublic String securityPay() {return "密码支付";}
}
// 扫脸支付--次维度规范实现类2
public class FaceMode implements PayMode {@Overridepublic String securityPay() {return "扫脸支付";}
}
// 指纹支付--次维度规范实现类3
public class FingerprintMode implements PayMode {@Overridepublic String securityPay() {return "指纹支付";}
}// 定义支付平台的抽象--主维度抽象方法
import lombok.Data;
@Data
public abstract class Pay {protected String payUser;protected String receiveUser;protected double money;protected PayMode payMode;   // 次维度的抽象属性public abstract String doPay();   // 支付方法
}
// 微信--主维度实现类1
public class WeChatPay extends Pay {public WeChatPay(Builder builder){this.payUser= builder.payUser;this.receiveUser= builder.receiveUser;this.money= builder.money;this.payMode= builder.payMode;}@Overridepublic String doPay() {   // 实现主维度方法return payUser+"使用微信-"+payMode.securityPay()+money+"元给"+receiveUser;}public static class Builder{     // 建造者模式private String payUser;private String receiveUser;private double money;private PayMode payMode;public Builder setPayUser(String payUser) {this.payUser = payUser;return this;}public Builder setReceiveUser(String receiveUser) {this.receiveUser = receiveUser;return this;}public Builder setMoney(double money) {this.money = money;return this;}public Builder setPayMode(PayMode payMode) {this.payMode = payMode;return this;}public WeChatPay build() {return new WeChatPay(this);}}
}
// 支付宝--主维度实现类2
public class AliPayPay extends Pay {public AliPayPay(Builder builder){this.payUser= builder.payUser;this.receiveUser= builder.receiveUser;this.money= builder.money;this.payMode= builder.payMode;}@Overridepublic String doPay() {  // 实现主维度方法return payUser+"使用支付宝-"+payMode.securityPay()+money+"元给"+receiveUser;}public static class Builder{    // 建造者模式private String payUser;private String receiveUser;private double money;private PayMode payMode;public Builder setPayUser(String payUser) {this.payUser = payUser;return this;}public Builder setReceiveUser(String receiveUser) {this.receiveUser = receiveUser;return this;}public Builder setMoney(double money) {this.money = money;return this;}public Builder setPayMode(PayMode payMode) {this.payMode = payMode;return this;}public AliPayPay build() {return new AliPayPay(this);}}
}
// 测试public static void main(String[] args) {System.out.println("桥接模式:");Pay wechatPay = new WeChatPay.Builder().setPayUser("张三").setReceiveUser("李四").setMoney(20.9).setPayMode(new PasswordMode()).build();System.out.println(wechatPay.doPay());Pay aliPay = new AliPayPay.Builder().setPayUser("张三").setReceiveUser("王五").setMoney(8.9).setPayMode(new FingerprintMode()).build();System.out.println(aliPay.doPay());}

运行结果:
在这里插入图片描述
说明:使用桥接模式,运行结果也满足需求。

3、桥接模式相对于直接调用的好处
1、解耦:使用桥接模式,如果扩展支付类型,仅通过新的类实现PayMode即可,不需要主维度代码修改;如果扩展支付平台,仅通过新的类实现Pay抽象类即可,不需要次维度代码修改;同时相对直接使用,更加准寻开闭原则。
2、代码逻辑更清晰,方便阅读。
3、更好的扩展方式。

但是桥接模式会增家类的定义和实现,一定层度上对框架的复杂度会有提升,所以实际场景还是根据自身情况决定比较好。

学海无涯苦作舟!!!

这篇关于Java设计模式 _结构型模式_桥接模式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/945772

相关文章

JavaScript的跳转传参方式

在JavaScript中,页面跳转并传递参数通常可以通过几种不同的方式来实现。下面是一些常见的方法: 1.URL参数(Query String) 这是最常见的方式,通过在URL的末尾添加参数来实现。例如: javascriptwindow.location.href = 'target.html?param1=value1&param2=value2'; 在target.html页面中,你

基于Springboot的学生心理压力咨询评判(有报告)。Javaee项目,springboot项目。

演示视频: 基于Springboot的学生心理压力咨询评判(有报告)。Javaee项目,springboot项目。 项目介绍: 采用M(model)V(view)C(controller)三层体系结构,通过Spring + SpringBoot + Mybatis+Vue+Maven+Layui+Elementui来实现。MySQL数据库作为系统数据储存平台,实现了基于B/S

Java码农的福音:再也不怕乱码了

即便是Java这样成熟的语言,开发者们也常常会遇到一个恼人的问题——乱码。 本文将深入探讨乱码的根本原因,并针对Java开发中的乱码场景提出有效的解决方案,辅以实战代码,让Java程序员从此告别乱码困扰。 一,字符集的故事 1,计算机不懂字符 敲代码时,键盘上输入的是字符,屏幕上显示的是字符,但计算机的大脑CPU其实根本不知道字符是什么,CPU能处理的只有二进制,即数字0和1。 键盘上

java算法实现之--输入一个英文句子,翻转句子中的单词顺序,但单词内字符的顺序不变

此题经常在笔试题中遇到,故特记录于此 public class Test {public static void main(String[] args) {String into = "I am a student";System.out.println(reverse(into));}public static String reverse(String into){String[] spli

2024OD机试卷-游戏分组 (java\python\c++)

题目:游戏分组 题目描述 部们准备举办一场 王者荣耀 表演赛,有 10 名游戏爱好者参与,分为两队,每队 5 人。 每位参与者都有一个评分,代表着他的游戏水平。为了表演赛尽可能精彩,我们需要把 10 名参赛者分为实力尽量相近的两队。 一队的实力可以表示为这一队 5 名队员的评分总和。 现在给你 10 名参与者的游戏水平评分,请你根据上述要求分队,最后输出这两组的实力差绝对值。 例:10 名参赛

Java环境搭配(一)JDK下载以及介绍、path环境变量配置

目录 JDK Development Kit  (JDK) 下载 JDK介绍 : JDK 包括以下主要组件 配置path环境变量 在cmd上打印Helloworld JDK Development Kit  (JDK) 下载 下载官方地址 www.oracle.com  进入网址后: 点击产品在硬件与软件中找到Java  接着点击右上角的下载  滑到下

springboot 序列化和反序列化

介绍 在Java中,序列化和反序列化是一种将对象转换为字节流或将字节流转换为对象的机制。通过序列化,可以将对象存储到文件中、传输到网络上,或者在分布式系统中进行对象的传递。本文将详细介绍Java序列化和反序列化的原理、使用方法和常见应用场景,并提供一些示例代码。 原理 Java序列化机制是基于对象的类结构进行的。当一个对象需要被序列化时,Java会将其转换为字节流,包括对象的数据和类

Java数据结构-HashMap(八)

Map接口的框架参考: http://blog.csdn.net/u010483016/article/details/45568281。 HashMap参考阅读:http://alex09.iteye.com/blog/539545,表示感谢。 AbstarctMap类实现了Map接口的大部分方法,避免了子类的重复实现,但是其中的一些方法对于大容量的Map来说效率不理想。HashMap继承了

Java数据结构-Map(七)

Map的定义: public interface Map<K,V>,是一个映射接口,其中存储的内容是键值对(key-value)。 每个键映射到一个值,不允许有重复的键。键和值的类型在申明Map的同时作出申明。 Map的框架图如下: 感谢 http://www.cnblogs.com/skywang12345/p/3308931.html 其中SortedMap实现了排序,因此

Java中的数组、Set、List、Map类型的互相转换总结

序言 数组、Set、List、Map是Java语言非常常用的几种数据类型,他们之间存在着千丝万缕的联系。关于底层的数据结构我这里就不再多说啦,直接从应用出发,总结他们之间的转换方法,并给出推荐方法。 大家可以点赞收藏等到需要的时候随时回顾查看使用!!! 如果将他们每两个类型的转换方式都总结一遍的,一共四种类型,再加上来回转换,每个转换都假设只讲一个方法,就要总结32次,因此这次不一一全部总结