Android设计模式--外观模式

news/2024/11/7 12:31:40/

弈之为术,在人自悟

一,定义

外观模式要求一个子系统的外部与其内部的通信必须通过一个统一的对象进行。提供一个高层次的接口,使得子系统更易于使用。

外观模式在开发中的使用频率是非常高的,尤其是在第三方的SDK里面,大部分都会使用外观模式。它通过一个外观类使得整个系统的接口只有一个统一的高层接口,这样能降低用户的使用成本,也对用户屏蔽了很多实现细节。在我们的开发过程中,外观模式也是我们封装API的常用手段,例如网络模块,图片加载等,可能你已经在开发中使用过无数次外观模式,只是没有在理论层面认识它。

二,使用场景

1,为一个复杂子系统提供一个简单接口。子系统往往因为不断演化而变得越来越复杂,甚至可能被替换。大多数模式使用时,都会产生更多更小的类,在这使子系统更具可重用性的同时也更容易对子系统进行定制,修改,这种易变形使得隐藏子系统的具体实现变得尤为重要。外观模式可以提供一个简单统一接口,对外隐藏子系统的具体实现,隔离变化。

2,当你需要构建一个层次结构的子系统时,使用外观模式定义子系统中每层的入口点。如果子系统之间是相互依赖的,你可以让他们仅通过外观模式的接口进行通信,从而简化了他们之间的依赖关系。

三,角色介绍

1,Facade:系统对外的统一接口,系统内部系统的工作。

2,SystemA,SystemB.......  :子系统接口

外观模式接口比较简单,就是通过一个统一的接口对外提供服务,使得外部程序只通过一个类就可以实现系统内部的多种功能,而这些实现功能的内部子系统之间可能也有交互,或者说完成一个功能需要几个子系统之间进行协作,如果没有封装,那么用户就需要操作几个子系统的交互逻辑,容易出现错误。而通过外观类来对外屏蔽这些复杂的交互,降低用户的使用成本。

四,使用案例

在英雄联盟游戏中,每个英雄都有各自的技能连招,比如盖伦的连招wqer,火男的连招weqr,光辉女郎的连招qwer等等,在市面上有一种宏键盘,可以定义一个按键一键释放连招。

在这里,我们假设q,w,e,r分别为一个子系统,他们内部有释放各自技能的方法。

宏键盘为对外的统一的类,定义F1键为火男的连招,F2键为盖伦的连招,F3键为光辉女郎的连招

首先,我们创建子系统的接口Q,W,E,R:

public interface Q {void useQ();
}
public interface W {void useW();
}
public interface E {void useE();
}
public interface R {void useR();
}

然后创建他们的具体实现类:

public class QImp implements Q{@Overridepublic void useQ() {System.out.println("使用了Q技能");}
}
public class WImp implements W{@Overridepublic void useW() {System.out.println("使用了W技能");}
}
public class EImp implements E{@Overridepublic void useE() {System.out.println("使用了E技能");}
}
public class RImp implements R{@Overridepublic void useR() {System.out.println("使用了R技能");}
}

最后,创建我们的对外的统一的类Facade宏键盘,它里面持有了Q,W,E,R的具体实现类的对象,对外提供了F1,F2,F3三个方法:

public class KBFacade {private QImp qImp =new QImp();private WImp wImp =new WImp();private EImp eImp =new EImp();private RImp rImp =new RImp();/*** 火男的连招* */public void F1(){System.out.println("使用火男的连招------");wImp.useW();eImp.useE();qImp.useQ();rImp.useR();System.out.println("火男的连招使用结束------");}/*** 盖伦的连招* */public void F2(){System.out.println("使用盖伦的连招------");wImp.useW();qImp.useQ();eImp.useE();rImp.useR();System.out.println("盖伦的连招使用结束------");}/*** 光辉的连招* */public void F3(){System.out.println("使用光辉的连招------");qImp.useQ();wImp.useW();eImp.useE();rImp.useR();System.out.println("光辉的连招使用结束------");}}

最后的使用:

KBFacade kbFacade =new KBFacade();
kbFacade.F1();
kbFacade.F2();
kbFacade.F3();

输出:

这样,使用的用户不需要知道火男的连招具体是什么,他只需要使用F1方法,就可以使用一系列的连招。

从上述代码中可以看到,外观模式就是统一接口封装。将子系统的逻辑,交互隐藏起来,为用户提供一个高层次的接口,使得系统更加易用,同时也对外隐藏了具体的实现,这样即使具体的子系统发生了变化,用户也不会感知到,因为用户使用的是Facade高层接口,内部的变化对于用户来说并不可见。这样一来就将变化隔离开来,使得系统也更为灵活。

五,总结

外观模式是一个高频率使用的设计模式,它的精髓就在于封装二字。通过一个高层次结构为用户提供统一的API入口,使得用户通过一个类型就基本能够操作整个系统,这样减少了用户的使用成本,也能够提升系统的灵活性。

优点:

1,对客户程序隐藏子系统细节,因而减少了客户对于子系统的耦合,能够拥抱变化。

2,外观类对子系统的接口封装,使得系统更易于使用。

缺点:

1,外观类接口膨胀。由于子系统的接口都有外观类统一对外暴露,使得外观类的API接口较多,在一定程度上增加了用户使用成本。

2,外观类没有遵循开闭原则,当业务出现变更时,可能需要直接修改外观类。


http://www.ppmy.cn/news/1241527.html

相关文章

TCP 重传、滑动窗口、流量控制、拥塞控制的剖析

TCP 是一个可靠传输的协议,那它是如何保证可靠的呢? 为了实现可靠性传输,需要考虑很多事情,例如数据的破坏、丢包、重复以及分片顺序混乱等问题。如不能解决这些问题,也就无从谈起可靠传输。 那么,TCP 是…

2. 寄存器

锁存器,用于存储1位的电路 只有当 可写位(write enable)开启,才会把输入写到输出,同时保存输出 使用锁存器 带时钟的锁存器 带时钟带可写控制的完整版锁存器 下面的时钟使用按钮来代替, 只有按钮为1时,相连的电路才工作时钟的作用在于协同所有电路共同工作,也是一切电路自动化…

MySQL- 创建可以远程访问的root账户

创建用户 默认的root用户只能当前节点localhost访问,是无法远程访问的,所以,我们要创建一个root账户,帮助用户远程访问。 create user root% IDENTIFIED WITH mysql_native_password BY 1234;这个命令是在MySQL数据库管理系统中…

每日OJ题_算法_双指针_力扣11. 盛最多水的容器

力扣11. 盛最多水的容器 11. 盛最多水的容器 - 力扣(LeetCode) 难度 中等 给定一个长度为 n 的整数数组 height 。有 n 条垂线,第 i 条线的两个端点是 (i, 0) 和 (i, height[i]) 。 找出其中的两条线,使得它们与 x 轴共同构成…

owl文件导入neo4j教程(win11)

一、前置条件 下载安装好neo4j 我是在官网下载的社区版4.4.28 下载neosemantics-4.4.0.3.jar 直接贴下载网址 https://objects.githubusercontent.com 下载rdf2rdf https://sourceforge.net/projects/rdf2rdf/ 下载并安装配置好jdk8 下载jdk11 二、步骤 1.使用如下命令将owl转…

基于STC12C5A60S2系列1T 8051单片读写掉电保存数据IIC总线器件24C02多字节并显示在液晶显示器LCD1602上应用

基于STC12C5A60S2系列1T 8051单片多字节读写掉电保存数据IIC总线器件24C02多字节并显示在液晶显示器LCD1602上应用 STC12C5A60S2系列1T 8051单片机管脚图STC12C5A60S2系列1T 8051单片机I/O口各种不同工作模式及配置STC12C5A60S2系列1T 8051单片机I/O口各种不同工作模式介绍IIC通…

论文笔记:详解NEUPSL DSI

《Using Domain Knowledge to Guide Dialog Structure Induction via Neural Probabilistic 》 名词解释 Dialog Structure Induction(DSI)是推断给定目标导向对话的潜在对话结构(即一组对话状态及其时间转换)的任务。它是现代对…

element-ui表格无法横向拖动问题

是不是用到了fixed // 因为我只有在小屏显示不下的时候才会出现这个问题所以我在这里做了适配(建议把样式放在全局) media screen and (max-width: 1800px) {// 由于使用了fixed导致横向条无法拖动出现bug.Table-page .el-table__fixed {height: auto !important;bottom: 2px …