热门手机游戏秘籍攻略应用教程大全

去重和排序是开辟过程当中常常遇到的题目,这篇文章就来总结一下。

去重

要领1:运用内置的distinct

代码以下:

//要领1:运用默许的distinct要领//只能针对基元范例列表,关于自定义范例组合字段前提须要自定义相称比较器完成IEqualityComparer接口,比较贫苦var result1 = list.Distinct().ToList();

要领2:运用GroupBy

代码以下:

//要领2:运用GroupByvar result2 = list.GroupBy(p => new { p.BunkCode, p.BunkPrice })
    .Select(p => p.First())
    .ToList();

要领3:运用本身扩大的DistinctBy要领

代码以下:

//要领3:运用本身扩大的DistinctBy要领//应用HashSet的key不能反复的特征var result3 = list.DistinctBy(p => new { p.BunkCode, p.BunkPrice })
    .ToList();

完全代码请参考:

/// <summary>/// 测试范例/// </summary>public class TestDistinctClass
{public int Id { get; set; }public string BunkCode { get; set; }public double BunkPrice { get; set; }
}/// <summary>/// 测试去重/// </summary>private static void TestDistinct()
{//数据源var list = new List<TestDistinctClass> 
    {new TestDistinctClass
        {
            Id= 1,
            BunkCode= "A",
            BunkPrice= 101},new TestDistinctClass
        {
            Id= 2,
            BunkCode= "B",
            BunkPrice= 102},new TestDistinctClass
        {
            Id= 3,
            BunkCode= "C",
            BunkPrice= 103},new TestDistinctClass
        {
            Id= 4,
            BunkCode= "D",
            BunkPrice= 104},new TestDistinctClass
        {
            Id= 5,
            BunkCode= "A",
            BunkPrice= 101}
    };//要领1:运用默许的distinct要领//只能针对基元范例列表,关于自定义范例组合字段前提须要自定义相称比较器完成IEqualityComparer接口,比较贫苦var result1 = list.Distinct().ToList();//要领2:运用GroupByvar result2 = list.GroupBy(p => new { p.BunkCode, p.BunkPrice })
        .Select(p => p.First())
        .ToList();//要领3:运用本身扩大的DistinctBy要领//应用HashSet的key不能反复的特征var result3 = list.DistinctBy(p => new { p.BunkCode, p.BunkPrice })
        .ToList();
}

同时,我把扩大要领也贴出来:

/// <summary>/// 扩大distinct/// </summary>/// <typeparam name="TSource"></typeparam>/// <typeparam name="TKey"></typeparam>/// <param name="source"></param>/// <param name="keySelector"></param>/// <returns></returns>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;
        }
    }
}

排序

至于排序,运用Linq供应的api就好了,以下图:

以上就是去重和排序怎样操纵的细致内容,更多请关注ki4网别的相干文章!

赞(0) 打赏
标签:

上一篇:

下一篇:

相关推荐

0 条评论关于"去重和排序怎样操纵【C#.Net教程】,排序,用的"

表情

最新评论

    暂无留言哦~~

支付宝扫一扫打赏

微信扫一扫打赏


Warning: error_log(/www/wwwroot/soxunxi.cn/wp-content/plugins/spider-analyser/#log/log-0919.txt): failed to open stream: No such file or directory in /www/wwwroot/soxunxi.cn/wp-content/plugins/spider-analyser/spider.class.php on line 2900