设计模式(三)-结构型模式(5)-外观模式

一、为何需要外观模式(Facade)?

要实现一个大功能,我们需要将它拆分成多个子系统。然后每个子系统所实现的功能,就由一个称为外观的高层功能模块来调用。这种设计方式就称为外观模式。该模式在开发时常常被使用过,所以很容易理解,就不多说了。

特点:

某个功能模块存在多个子系统时,每个子系统实现各自的子任务,并且将它们组合在一起来完成一个完整的任务。

结构:

Facade(外观类):为子任务提供一个共同对外的高层接口。在客户端调用它的方法。

SubSystem(子系统类):实现子系统的功能。可以被外观类调用,也可以直接被客户端调用。

二、例子

需求:

实现一个登录帐户的功能,登录分为验证码验证、连接服务器、从数据库匹配帐户和密码的三个主要步骤。

c 复制代码
//SubSystem:子系统(服务器)
    public class Server
    {
        public void SocketToServer()
        {
            Console.WriteLine("连接服务器。");
        }
    }

    //SubSystem:子系统(验证码)
    public class VeriCode
    {
        public bool doVeriCode(string code)
        {
            Console.WriteLine("{0}验证成功!", code);
            return true;
        }
    }

    //SubSystem:子系统(数据库)
    public class Database
    {
        //假设这个字典所存的数据是来自数据库里的。
        private Dictionary<int, string> UserInfos = new Dictionary<int, string>()
        {
           {123,"abc" },
           {456,"xyz" },
           {789,"abc123"},
        };

        //是否跟数据库里的信息匹配
        public bool isExist(int userId, string pwd)
        {
            bool isExist = UserInfos.Contains(new KeyValuePair<int, string>(userId, pwd));
            return isExist;
        }

    }

    //Facade:外观(登录)
    public class LogOnFacade
    {
        private Server server;
        private VeriCode veriCode;
        private Database database;
        public LogOnFacade()
        {
            server = new Server();
            veriCode = new VeriCode();
            database = new Database();
        }

        public bool IsCode(string code)
        {
            return veriCode.doVeriCode(code);
        }

        public bool LogOnUser(int userId,string pwd)
        {
            server.SocketToServer();
           return database.isExist(userId, pwd);
        }

    }

    //主程序
    class Program
    {
        static void Main(string[] args)
        {
            LogOnFacade logOn = new LogOnFacade();

            logOn.IsCode("qwe1");
            var isSuccess = logOn.LogOnUser(123, "abc");

            var result = isSuccess ? "登录成功" : "登录失败";
            Console.WriteLine(result);

            Console.ReadLine();
        }
    }
相关推荐
百度智能云技术站5 小时前
广告投放系统成本降低 70%+,基于 Redis 容量型数据库 PegaDB 的方案设计和业务实践
数据库·redis·oracle
梦想平凡7 小时前
PHP 微信棋牌开发全解析:高级教程
android·数据库·oracle
夏木~9 小时前
Oracle 中什么情况下 可以使用 EXISTS 替代 IN 提高查询效率
数据库·oracle
思忖小下10 小时前
梳理你的思路(从OOP到架构设计)_简介设计模式
设计模式·架构·eit
吴冰_hogan10 小时前
MySQL InnoDB 存储引擎 Redo Log(重做日志)详解
数据库·oracle
CodeCraft Studio10 小时前
【实用技能】如何在 SQL Server 中处理 Null 或空值?
数据库·oracle·sqlserver
武汉联从信息10 小时前
浅谈ORACLE中间件SOA BPM,IDM,OID,UCM,WebcenterPortal服务器如何做迁移切换
oracle
Elastic 中国社区官方博客11 小时前
Elasticsearch:什么是查询语言?
大数据·数据库·elasticsearch·搜索引擎·oracle
liyinuo201712 小时前
嵌入式(单片机方向)面试题总结
嵌入式硬件·设计模式·面试·设计规范
夜光小兔纸12 小时前
oracle dblink 的创建及使用
数据库·oracle