• 使用C#的Flags特性


    举个例子:我有如下的一个需求,当我想要取得用户信息的时候,会先从本地缓存中查找,找不到然后从分布式缓存中查找,最后找不到再从数据库中查询。但是有些场景我又不需要查询数据库。

    所以我想建立如下这种模型。

    public UserEntity  GetUserInfo(List<DataSource>  dataSources)
    {
        var xxxx = new UserEntity();
        if(dataSources.Any(DataSource.Local)
        {
            //从本地缓存中获取
            return xxxx;
        }
    
        if(dataSources.Any(DataSource.Distribution)
        {
            //从分布式缓存中获取
            //更新本地缓存
            return xxxx;
        }
    
        if(dataSources.Any(DataSource.DB)
        {
            //从DB中获取
            //更新分布式缓存
            //更新本地缓存
        }
        return xxxx;
    }
    

    但是每次调用者都去构建一个List,比较麻烦,此时我们可以使用枚举中的Flags特性,修改程序如下:

    首先是枚举的定义上,要加上   [Flags] 特性标签,并且定义 一般都是 2的n次方,主要是便于位移运算

        /// <summary>
        ///  数据取得地方
        /// </summary>
        [Flags]
        public enum DataSource 
        {
            /// <summary>
            ///     本地缓存
            /// </summary>
            [Description("本地缓存")]
            LocalCache = 1,
    
            /// <summary>
            ///    分布式缓存
            /// </summary>
            [Description("分布式缓存")]
            DistributeCache = 2,
    
            /// <summary>
            ///     数据库
            /// </summary>
            [Description("数据库")]
            DB = 4,
        }
    

    修改代码:

    public UserEntity  GetUserInfo(DataSource dataSources)
    {
        var xxxx = new UserEntity();
        if(dataSources.HasFlags(DataSource.Local)
        {
            //从本地缓存中获取
            return xxxx;
        }
    
        if(dataSources.HasFlags(DataSource.Distribution)
        {
            //从分布式缓存中获取
            //更新本地缓存
            return xxxx;
        }
    
        if(dataSources.HasFlags(DataSource.DB)
        {
            //从DB中获取
            //更新分布式缓存
            //更新本地缓存
        }
        return xxxx;
    }
    

    调用的地方,可以通过“|”来指定,例如我只想用分布式缓存和数据库,那么:

    var userInfo = GetUserInfo(DataSource.Distribution | DataSource.DB);
  • 相关阅读:
    MYSQL删除表的记录后如何使ID从1开始
    Python chardet 字符编码判断
    中文搜索引擎技术揭密
    python 处理中文网页时,忽略特殊字符,忽略异常
    cmd 之基础命令
    自己写的删除主键的存储过程
    朝花夕拾delphi的三层结构
    ERWIN中的一对多标识关系和一对多非标识关系
    翻页用的SQL
    关于 Ajax 的一篇通俗易懂的文章
  • 原文地址:https://www.cnblogs.com/dcz2015/p/10943759.html
Copyright © 2020-2023  润新知