设计模式(三)-结构型模式(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 小时前
OCI编程高级篇(八) LOB写操作
oracle·asm·dul·oracle oci 编程
laizhenghua6 小时前
解决:[64000][257] ORA-00257: 归档程序错误。只有在解析完成后才以 AS SYSDBA 方式连接问题
oracle
꒰ঌ 安卓开发໒꒱10 小时前
SQL Server安全删除数据并释放空间的技术方案
数据库·安全·oracle
kura_tsuki11 小时前
[Oracle数据库] ORACLE的用户维护和权限操作
数据库·oracle
吴声子夜歌15 小时前
PostgreSQL——索引
数据库·postgresql·oracle
一个有梦有戏的人1 天前
软考架构师:数据库的范式
数据库·oracle
tianchang1 天前
打造你的本地AI助手:基于RAG+向量数据库的智能问答系统
人工智能·设计模式·node.js
IT小白架构师之路2 天前
常用设计模式系列(十八)-责任链模式
设计模式·责任链模式
源代码•宸2 天前
深入浅出设计模式——行为型模式之观察者模式 Observer
开发语言·c++·经验分享·观察者模式·设计模式·raii
liulanba2 天前
Redis 缓存问题详解及解决方案
redis·缓存·oracle