• 设计模式第八篇-外观模式


    一、引言

    电商项目中一个常见场景:提交订单操作,提交订单后有很多后续动作,例如:检查订单, 创建订单, 减库存,创建支付链接等等,这些子类的内部操作都很复杂。如果我们的客户端程序要直接跟这些内容子系统进行耦合,那么客户端就得随着子系统的改动而改动。提交订单操作在一个电商系统中很多地方都会出现,如果每个地方都进行了耦合,那一旦进行改动是非常苦难的。

    这个时候我们需要一个高级接口,将子系统包装起来,提供一个客户端可以访问系统的接口,将内部系统的复杂性隐藏起来,这就是外观模式。

    二、外观模式

    定义:外观模式提供了一个统一的接口,用来访问子系统中的一群接口。外观定义了一个高层接口,让子系统更容易使用。

    主要解决:降低访问复杂系统的内部子系统时的复杂度,简化客户端与之的接口。

    何时使用: 1、客户端不需要知道系统内部的复杂联系,整个系统只需提供一个"接待员"即可。 2、定义系统的入口。

    如何解决:客户端不与系统耦合,外观类与系统耦合。

    类图:

    三、代码实现

    //检查订单
    public class CheckOrder {
        public void check() {
            System.out.println("检查订单...");
        }
    }
    //创建订单
    public class AddOrder {
        public void add(){
            System.out.println("新增订单...");
        }
    }
    //减库存
    public class SubInventory {
        public void sub(){
            System.out.println("减去库存...");
        }
    }
    //下单外观类
    public class OrderFacade {
        private AddOrder addOrder;
        private CheckOrder checkOrder;
        private SubInventory subInventory;
    
        public OrderFacade(){
            addOrder=new AddOrder();
            checkOrder=new CheckOrder();
            subInventory=new SubInventory();
        }
        //入口方法
        public void order(){
            checkOrder.check();
            addOrder.add();
            subInventory.sub();
        }
    }

    结果:

    四、总结

    优点: 1、减少系统相互依赖。 2、提高灵活性。 3、提高了安全性。

    缺点:不符合开闭原则,如果要改东西很麻烦,继承重写都不合适。

    使用场景: 1、为复杂的模块或子系统提供外界访问的模块。 2、子系统相对独立。 3、预防低水平人员带来的风险。

    注意事项:在层次化结构中,可以使用外观模式定义系统中每一层的入口

  • 相关阅读:
    Redis简单梳理及集群配置
    PDF.js 详情解说
    基于SMS短信平台给手机发送短信
    linux装OpenOffice后传---中文乱码的解决
    NodeJs小试牛刀--聊天室搭建
    算法之路--最小代价生成树
    Linux系统上安装OpenOffice
    项目部署之工具使用心得
    H5 Handlebars的简单使用
    JavaWeb国际化
  • 原文地址:https://www.cnblogs.com/yuanqinnan/p/10271538.html
Copyright © 2020-2023  润新知