• ConcurrentDictionary<TKey, TValue>的AddOrUpdate方法


    https://msdn.microsoft.com/zh-cn/library/ee378665(v=vs.110).aspx

    此方法有一共有2个,现在只讨论其中一个

    public TValue AddOrUpdate(
    TKey key,
    TValue addValue,
    Func<TKey, TValue, TValue> updateValueFactory
    )

    Parameters 参数说明

    key 参数名称    【此参数不允许为null】
    Type: TKey 参数类型
    The key to be added or whose value should be updated 需要添加或者更新的key


    addValue 参数名称
    Type: TValue 参数类型
    The value to be added for an absent key 和新key匹配的value


    updateValueFactory 参数名称    【此参数不允许为null】
    Type: System.Func<TKey, TValue, TValue> 参数类型
    The function used to generate a new value for an existing key based on the key's existing value 此函数用来基于已有的key的value来生成新的值


    Return Value 返回值
    Type: TValue 返回值的类型
    The new value for the key. This will be either be addValue (if the key was absent) or the result of updateValueFactory (if the key was present).

    key对应的新value,可能是新添加的,也可能是更新的

    假定目前有一个ConcurrentDictionary<string, Dictionary<string, Color>> dictionary,需要给它添加新的值

    方法1:使用委托,写一个符合委托签名的方法

    private Dictionary<string,Color> Method(string deviceId,Dictionary<string,Color> dic)
    {
    return dic;
    }

    调用的时候,       dictionary.AddOrUpdate(warningInfo.DeviceID, dic, Method);   //将Method作为参数进行传递

    方法2:使用匿名委托

    dictionary.AddOrUpdate(warningInfo.DeviceID, dic, delegate(string deviceId,Dictionary<string,Color> dic1)
    {
    return dic1;
    });

    方法3:直接使用lambda表达式

     dictionary.AddOrUpdate(warningInfo.DeviceID, dic, (key, value) => value);

    假如有多个ConcurrentDictionary的变量,都需要使用AddOrUpdate函数,并且第三个参数updateValueFactory的逻辑相同【目前假设逻辑仅仅是返回Value的值】

    可以将updateValueFactory抽象成一个泛型方法来使用

     /// <summary>
        /// GenericMethod类,用于存放泛型方法[但是这个类本身不是泛型的]
        /// </summary>
        public class GenericMethod
        {
            /// <summary>
            ///  System.Collections.Concurrent.ConcurrentDictionary类中AddOrUpdate方法中的第三个参数对应的一个泛型方法
            ///  目前的AddOrUpdate方法中的第三个三处Func委托只需要返回Value就可以了,不需要做其他的处理
            /// </summary>
            /// 参数
            /// <param name="key">第一个参数</param>
            /// <param name="value">第二个参数</param>
            /// 类型参数
            /// <typeparam name="TKey">第一个参数的类型</typeparam>
            /// <typeparam name="TValue">第二个参数的类型</typeparam>
            /// <returns></returns>
            public static TValue UpdateValueFactory<TKey, TValue>(TKey key, TValue value)
            {
                return value;
            }
        }
  • 相关阅读:
    分享一个自己写的vue多语言插件smart-vue-i18n
    利用vw+rem实现移动web适配布局
    你说前端不了解业务?
    小程序开发总结一:mpvue框架及与小程序原生的混搭开发
    小码农的职场人生一:由张小平离职引发的一些吐槽
    javascript本地缓存方案-- 存储对象和设置过期时间
    手淘移动适配方案flexible.js兼容bug处理
    微信小程序入坑之自定义组件
    vuejs开发组件分享之H5图片上传、压缩及拍照旋转的问题处理
    非域环境下使用证书部署数据库(SqlServer2008R2)镜像
  • 原文地址:https://www.cnblogs.com/chucklu/p/4468057.html
Copyright © 2020-2023  润新知