• 脚印:记录一次重构,将规则生产和规则消费(执行委托)分离


    重构前:

    Cache.Add(DXCacheKey.A, Register(DXCacheKey.A, DXCacheKeyType.A, dal.GetItemA, dal.GetItemAById)); Cache.Add(DXCacheKey.B, Register(DXCacheKey.B, DXCacheKeyType.B, dal.GetItemB, dal.GetItemBById));
    ...
    ...

    此次重构的目标是将规则的建立和使用进行分离(IDXCacheItemWrapper), 副产品是将某一形式的规则进行了封装(DXCacheItemWrapper)。

    分离的好处:

    一是,增强了代码的的可读性。因为这是个较为自然的过程,先创建规则,然后使用它。

    二是,其他形式的规则,只要符合IDXCacheItemWrapper,也可以加入到计算任务中来。

    三是,规则建立好后,不必立即使用,可以延迟计算。在此期间,可以对规则集进行筛选,增补等操作。

    publicclass Class1
    {
    public Class1()
    {
    DAL dal
    =new DAL();
    List
    <IDXCacheItemWrapper> list =new List<IDXCacheItemWrapper>
    {
    new DXCacheItemWrapper<ItemA, int>(DXCacheKey.A, DXCacheKeyType.A, dal.GetItemA, dal.GetItemAById),
    new DXCacheItemWrapper<ItemB, int>(DXCacheKey.B, DXCacheKeyType.B, dal.GetItemB, dal.GetItemBById),
    new DXCacheItemWrapper<ItemC, int>(DXCacheKey.C, DXCacheKeyType.C, dal.GetItemC, dal.GetItemCById),
    };

    foreach (IDXCacheItemWrapper w in list)
    {
    var value
    = w.GetValue();
    Cache.Add(w.Key.ToString(), value);
    }
    }

    }


    publicinterface IDXCacheItemWrapper
    {
    DXCacheKey Key {
    get; set; }

    object GetValue();
    }

    publicclass DXCacheItemWrapper<T1, T2> : IDXCacheItemWrapper
    {
    public DXCacheItemWrapper(DXCacheKey key, DXCacheKeyType keyType, Func<T1> getData1, Func<T2, T1> getData2)
    {
    Key
    = key;
    KeyType
    = keyType;
    GetData1
    = getData1;
    GetData2
    = getData2;
    }

    publicobject GetValue()
    {
    return GetValue<T1, T2>(Key, KeyType, GetData1, GetData2);
    }

    public T1 GetValue<T1, T2>(DXCacheKey key, DXCacheKeyType keyType, Func<T1> f1, Func<T2, T1> f2)
    {
    returndefault(T1);
    }

    public DXCacheKey Key { get; set; }
    public DXCacheKeyType KeyType { get; set; }
    public Func<T1> GetData1 { get; set; }
    public Func<T2, T1> GetData2 { get; set; }
    }

      

  • 相关阅读:
    小白日记41:kali渗透测试之Web渗透-SQL手工注入(三)-猜测列名、表名、库名、字段内容,数据库写入
    Python实现百度贴吧自动顶贴机
    回文自动机简述
    计算几何基本知识整理
    考试题Speed
    [ZOJ 2112] [lg2617] Dynamic Rankings
    后缀数组(Suffix Arrary)
    莫比乌斯函数与莫比乌斯反演
    题解 洛谷 P3369 【【模板】普通平衡树】
    EXCRT(扩展中国剩余定理)
  • 原文地址:https://www.cnblogs.com/yicone/p/2110870.html
Copyright © 2020-2023  润新知