温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

C# 删除Collections中的重复数据

发布时间:2020-06-21 13:57:24 来源:网络 阅读:376 作者:13713878410 栏目:编程语言
  • List去重


通过扩展方法System.Linq.Enumerable.Distinct()

对于简单数据类型,可以简单的调用这个函数就行啦,因为它会使用默认的比较器(System.Collections.Generic.EqualityComparer<T>.Default)。

 Default   属性检查类型 T 是否实现此 System.IEquatable<T> 泛型接口,如果实现,该属性将返回一个包含 IEquatable<T>.Equals 方法的实现的 EqualityComparer<T>。否则,它返回 T 提供的 EqualityComparer<T>

对于类数据类型,需要定义一个IEqualityComparer<T>接口的实现类,或在类中直接实现System.IEquatable<T>或IEqualityComparer<T>。


例子1:

private static List<EquityUniverse> DistinctEstimatesUniverse(List<EquityUniverse> universeList)
 {
      return universeList.Distinct(new UniverseComparer()).ToList();
 }
public class UniverseComparer : IEqualityComparer<EquityUniverse>
    {
        public bool Equals(EquityUniverse x, EquityUniverse y)
        {
            if (Object.ReferenceEquals(x, y)) return true;
            return x.GlobalEntityId.Equals(y.GlobalEntityId) && x.CountryId.Equals(y.CountryId);
        }
        public int GetHashCode(EquityUniverse obj)
        {
            return obj.CountryId.GetHashCode() ^ obj.GlobalEntityId.GetHashCode();
        }
    }


向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI