美文网首页Java设计模式
简易理解设计模式之:外观模式——第三方SDK的帮助类

简易理解设计模式之:外观模式——第三方SDK的帮助类

作者: 大亮亮亮亮 | 来源:发表于2019-03-11 10:19 被阅读3次

    介绍:

    外观模式属于结构型模式。它为子系统中的一组接口提供一个一致的界面,此模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。

    类图:

    外观模式UML类图.png

    Facade(外观角色):为子系统统一接口。
    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的帮助类。

    感谢您的阅读~

    转载请注明出处喔:https://www.jianshu.com/p/45dcde8a0715

    相关文章

      网友评论

        本文标题:简易理解设计模式之:外观模式——第三方SDK的帮助类

        本文链接:https://www.haomeiwen.com/subject/sdacpqtx.html