介绍:
外观模式属于结构型模式。它为子系统中的一组接口提供一个一致的界面,此模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。
类图:
外观模式UML类图.pngFacade(外观角色):为子系统统一接口。
System(子系统角色):具有各种复杂行为。
用法:
• 用外观模式解耦降低了用户的使用成本。(例如在设计代码初段,应该有意识地将不同的层分离。如经典的MVC模式中,View层和Model层界面与数据的分离,Controller担任外观角色)
• 为一个复杂子系统提供一个简单接口。(子系统往往会不断变化而变得越来越难维护,这种易变性使得隐藏子系统的具体变化极为重要)
• 维护一个大型遗留的系统时。(让外观角色为遗留代码设计一个简单的接口,让新系统和外观角色交互)
个人理解:
这个模式非常简单,为一个或多个系统提供一个简单的接口。需要跟复杂系统交互的时候可以考虑使用这个模式。
例子:
专注开发工作的你一定使用过此模式,就在我们接入第三方SDK的时候,都会有意识地用一个“帮助类”去跟SDK具体方法交互,只关心自己需要用的数据。下面用一个TalkingData第三方SDK的帮助类过一下:
需求:模拟SDK的使用
1、TalkingDataSDK的使用
首先简单介绍TalkingData,是专门做数据统计的公司,可以根据自己需求组合各种子SDK,例如页面埋点、点击事件分析、支付的漏洞模型等等。在这里非常适合使用外观模式去封装。
1.1、核心部分
/**
* 初始化TalkingData SDK
*
* @param context
*/
public void initTDSDK(Context context) {
try {
TalkingDataAppCpa.init(context, "123123123123123123", MainApplication.FLAVOR);
TCAgent.init(context, "456456456456456", MainApplication.FLAVOR);
} catch (Exception e) {
e.printStackTrace();
}
}
初始化SDK时,我们同时初始化两个子系统TalkingDataAppCpa和TCAgent。
对于程序员来说,封装一齐的目的是他们是同一家公司的两个子系统,我未来还可能接入更多的该公司的功能,就一并放在这个类方便管理。
1.2、各种子系统的方法举例
/**
* 关闭TalkingData SDK日志输出
*/
public void disableDebug() {
TalkingDataAppCpa.setVerboseLogDisable();
}
/**
* 注册成功事件
*
* @param mid 用户member_id
*/
public void onRegister(String mid) {
TalkingDataAppCpa.onRegister(mid);
}
/**
* 登录成功事件
*
* @param mid 用户member_id
*/
public void onLogin(String mid) {
TalkingDataAppCpa.onLogin(mid);
}
/**
* 下单事件
*
* @param mid 用户member_id
*/
public void onOrder(String mid, String orderId, String totalPrice) {
Order order = Order.createOrder(orderId, (int) (Float.parseFloat(totalPrice) * 100), "CNY");
TalkingDataAppCpa.onPlaceOrder(mid, order);
}
/**
* 支付成功事件
*
* @param mid 用户member_id
*/
public void onPaySucceed(String mid, String orderId, String amount, String paytype) {
TalkingDataAppCpa.onOrderPaySucc(mid, orderId, (int) (Float.parseFloat(amount) * 100), "CNY", paytype);
}
/**
* 事件管理-点击事件
*
* @param context Activity上下文
* @param eventId 事件ID
* @param eventLabel 事件标签
* @param eventDetail 事件细节
*/
public void onEvent(Context context, String eventId, String eventLabel, Map eventDetail) {
TCAgent.onEvent(context, eventId, eventLabel, eventDetail);
}
/**
* 进入页面
* @param context
* @param pageName 页面名称。
* onPageStart 和 onPageEnd 必须成对调用;
*/
public void onPageStart(Context context,String pageName){
TCAgent.onPageStart(context,pageName);
}
/**
* 退出页面
* @param context
* @param pageName
*/
public void onPageEnd(Context context,String pageName {
TCAgent.onPageEnd(context,pageName);
}
使用者不需要知道具体的实现,完全隐藏了实现细节。另一方面,随着SDK不停地迭代更新,实现方法有可能变得面目全非。因此后续维护工作只在这个类完成就可以了,否则改动一个方法需要在你所有的实现的地方都改一遍可多崩溃。
2、总结
此模式比较常用,相信你已经在不知不觉中使用了!主要用法还是作为一些第三方SDK的帮助类。
感谢您的阅读~
网友评论