| 现在对不同手机类型的不同品牌实现操作编程(比如:开机、关机、上网,打电话等) |

- 如果用代码实现,需要写很多重复的类

| 1) 扩展性问题(类爆炸),如果我们再增加手机的样式(旋转式),就需要增加各个品牌手机的类,同样如果我们增加一个手机品牌,也要在各个手机样式类下增加。 |
| 2) 违反了单一职责原则,当我们增加手机样式时,要同时增加所有品牌的手机,这样增加了代码维护成本. |
| 3) 解决方案-使用桥接模式 |
| 1) 桥接模式(Bridge模式)是指:将实现与抽象放在两个不同的类层次中,使两个层次可以独立改变。 |
| 2) 是一种结构型设计模式 |
| 3) Bridge模式基于类的最小设计原则,通过使用封装、聚合及继承等行为让不同的类承担不同的职责。它的主要特点是把抽象(Abstraction)与行为实现(Implementation)分离开来,从而可以保持各部分的独立性以及应对他们的功能扩展 |
- 桥接模式原理类图

| 1) Client 类:桥接模式的调用者 |
| 2) 抽象类(Abstraction) :维护了 Implementor / 即它的实现类 ConcreteImplementorA.., 二者是聚合关系, Abstraction充当桥接类 |
| 3) RefinedAbstraction : 是 Abstraction 抽象类的子类 |
| 4) Implementor : 行为实现类的接口 |
| 5) ConcreteImplementorA /B :行为的具体实现类 |
| 6) 从 UML 图:这里的抽象类和接口是聚合的关系,其实调用和被调用关系 |

| package com.atguigu.bridge; |
| |
| public interface Brand { |
| void open(); |
| void close(); |
| void call(); |
| } |
| |
| package com.atguigu.bridge; |
| public class Vivo implements Brand { |
| |
| @Override |
| public void open() { |
| |
| System.out.println(" Vivo手机开机 "); |
| } |
| |
| @Override |
| public void close() { |
| |
| System.out.println(" Vivo手机关机 "); |
| } |
| |
| @Override |
| public void call() { |
| |
| System.out.println(" Vivo手机打电话 "); |
| } |
| |
| } |
| |
| package com.atguigu.bridge; |
| public class XiaoMi implements Brand { |
| |
| @Override |
| public void open() { |
| |
| System.out.println(" 小米手机开机 "); |
| } |
| |
| @Override |
| public void close() { |
| |
| System.out.println(" 小米手机关机 "); |
| } |
| |
| @Override |
| public void call() { |
| |
| System.out.println(" 小米手机打电话 "); |
| } |
| |
| } |
| |
| package com.atguigu.bridge; |
| public abstract class Phone { |
| |
| |
| private Brand brand; |
| |
| |
| public Phone(Brand brand) { |
| super(); |
| this.brand = brand; |
| } |
| |
| protected void open() { |
| this.brand.open(); |
| } |
| |
| protected void close() { |
| brand.close(); |
| } |
| |
| protected void call() { |
| brand.call(); |
| } |
| |
| } |
| |
| package com.atguigu.bridge; |
| |
| public class FoldedPhone extends Phone { |
| |
| |
| public FoldedPhone(Brand brand) { |
| super(brand); |
| } |
| |
| public void open() { |
| super.open(); |
| System.out.println(" 折叠样式手机 "); |
| } |
| |
| public void close() { |
| super.close(); |
| System.out.println(" 折叠样式手机 "); |
| } |
| |
| public void call() { |
| super.call(); |
| System.out.println(" 折叠样式手机 "); |
| } |
| } |
| |
| package com.atguigu.bridge; |
| public class UpRightPhone extends Phone { |
| |
| |
| public UpRightPhone(Brand brand) { |
| super(brand); |
| } |
| |
| public void open() { |
| super.open(); |
| System.out.println(" 直立样式手机 "); |
| } |
| |
| public void close() { |
| super.close(); |
| System.out.println(" 直立样式手机 "); |
| } |
| |
| public void call() { |
| super.call(); |
| System.out.println(" 直立样式手机 "); |
| } |
| } |
| |
| package com.atguigu.bridge; |
| public class Client { |
| |
| public static void main(String[] args) { |
| |
| Phone phone1 = new FoldedPhone(new XiaoMi()); |
| phone1.open(); |
| phone1.call(); |
| phone1.close(); |
| |
| System.out.println("======================="); |
| Phone phone2 = new FoldedPhone(new Vivo()); |
| phone2.open(); |
| phone2.call(); |
| phone2.close(); |
| |
| System.out.println("=============="); |
| UpRightPhone phone3 = new UpRightPhone(new XiaoMi()); |
| phone3.open(); |
| phone3.call(); |
| phone3.close(); |
| |
| System.out.println("=============="); |
| UpRightPhone phone4 = new UpRightPhone(new Vivo()); |
| phone4.open(); |
| phone4.call(); |
| phone4.close(); |
| } |
| |
| } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 字符编码:从基础到乱码解决
· 提示词工程——AI应用必不可少的技术
2021-08-31 vue开发:前端项目模板