Linq利用Distinct去除重复项(可自己指定)

public static IEnumerable<TSource> DistinctBy<TSource, TKey> (this IEnumerable<TSource> source, Func<TSource, TKey> keySelector)
{
    HashSet<TKey> seenKeys = new HashSet<TKey>();
    foreach (TSource element in source)
    {
        if (seenKeys.Add(keySelector(element)))
        {
            yield return element;
        }
    }

使用方法如下(针对ID,和Name进行Distinct)
var query = people.DistinctBy(p => new { p.Id, p.Name });

若仅仅针对ID进行distinct:
var query = people.DistinctBy(p => p.Id);

上一篇:JAVA输入输出及随机数的生成


下一篇:Java学习第十一天<构造器详解><创建对象内存分析><类与对象简单小结>