微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

C# List 根据对象属性去重的四种方法对比

测试代码

private void Testdistinct()
{
    Task.Run(() =>
    {
        //生成测试数据
        DateTime dt = DateTime.Now;
        Random rnd = new Random();
        List<MyData> list = new List<MyData>();
        int total = 1000000;
        for (int i = 0; i < total; i++)
        {
            MyData info =  MyData();
            info.id = rnd.Next(1,total * 10).ToString();
            info.name = rnd.Next().ToString();
            list.Add(info);
        }
        double d = DateTime.Now.Subtract(dt).TotalMilliseconds;

        方法
        DateTime dt1 = DateTime.Now;
        Dictionary<string,MyData> result1 = new Dictionary<foreach (MyData item in list)
        {
            MyData temp;
            if (!result1.TryGetValue(item.name,out temp))
            {
                result1.Add(item.name,item);
            }
        }
        List<MyData> r1 = result1.Values.ToList();
        double d1 = DateTime.Now.Subtract(dt1).TotalMilliseconds;

        方法
        DateTime dt2 = DateTime.Now;
        List<MyData> result2 = list.ToLookup(item => item.name).ToDictionary(item => item.Key,item => item.First()).Values.ToList();
        double d2 = DateTime.Now.Subtract(dt2).TotalMilliseconds;

        方法
        DateTime dt3 = DateTime.Now;
        List<MyData> result3 = list.distinct( MyCompare()).ToList();
        double d3 = DateTime.Now.Subtract(dt3).TotalMilliseconds;

        方法
        DateTime dt4 = DateTime.Now;
        List<MyData> result4 = list.GroupBy(item => item.name).Select(item => item.First()).ToList();
        double d4 = DateTime.Now.Subtract(dt4).TotalMilliseconds;

        this.BeginInvoke(new Action(() =>
        {
            textBox1.Text = "";
            textBox1.Text += "生成 " + list.Count.ToString(# ####") +  条测试数据耗时:" + d + 毫秒\r\n\r\n"使用方法一去重耗时:" + d1 + 使用ToLookup和ToDictionary去重耗时:" + d2 + 使用distinct去重耗时:" + d3 + 使用GroupBy和Select去重耗时:" + d4 + 去重后数量" + r1.Count + " + result2.Count + " + result3.Count + " + result4.Count + "" + \r\n\r\n;
        }));
    });
}
View Code

数据类:

public class MyData
{
    string id { get; set; }
    string name { ; }
}

class MyCompare : IEqualityComparer<MyData>
{
    bool Equals(MyData x,MyData y)
    {
        return x.name == y.name;
    }

    int GetHashCode(MyData obj)
    {
        return obj.name.GetHashCode();
    }
}
View Code

测试结果:

结论:

方法一和方法三去重速度差不多,在一个数量

方法二和方法四去重速度差不多,在一个数量

方法二和方法四比方法一和方法三大约慢4、5倍左右

方法二和方法四比较方便,一行代码搞定,方法一和方法代码行数相对较多,方法三要写个MyCompare

 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐