C#中使用Lambda表达式自定义比较器实现两个列表合并实例

所属分类: 软件编程 / C#教程 阅读数: 75
收藏 0 赞 0 分享

一次项目有这样的需求,本地存储了json数据,可以转化为对应的List列表,现在需要更新,从服务器那里获取最新的数据更改。总的来说就是本地有个List表,如果数据需要更新,则会向服务器发送请求来获取需要更改的部分List表格,然后客户端这边就要去处理合并完整这次的更新,弄了一个下午,终于搞定,这次来mark一下。

主要推送的数据的两个特性:

1.如果之前的列表需要增加,则出现在最新的数据推送List中

2.如果数据需要修改的话,则一样推送更新,保持id不变,内容有所改变

示例代码如下图:

复制代码 代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace test
{
    public class date
    {
        public int id { set; get; }
        public string color { set; get; }
        public string name { set; get; }
        public decimal price { set; get; }

        public string time { get; set; }
    }

    class MyComparer : IEqualityComparer<date>
    {
        public bool Equals(date x, date y)
        {
            return x.id == y.id;
        }

        public int GetHashCode(date obj)
        {
            return obj.id.GetHashCode();
        }
    }

    class Program
    {
        static void Main(string[] args)
        {
            List<date> list1 = new List<date>()
            {
                new date() { id = 1, color = "1", name = "name1", price = 1,time="时间" },
                new date() { id = 2, color = "2", name = "name2", price = 2,time="时间" },
                new date() { id = 3, color = "3", name = "name3", price = 3,time="时间" },
                new date() { id = 5, color = "5", name = "name5", price = 5,time="时间" },
                new date() { id = 6, color = "6", name = "name8", price = 8,time="时间" }
            };
            List<date> list2 = new List<date>()
            {
                new date() { id = 1, color = "修改", name = "修改", price = 2,time="时间" },
                new date() { id = 8, color = "增加", name = "增加", price = 2,time="时间" }
            };
            var result = list2.Union(list1, new MyComparer());
            foreach (var item in result)
            {
                Console.WriteLine("id = {0}, card = {1}, name = {2}, price = {3}", item.id, item.color, item.name, item.price,item.time);
            }
        }
    }
}

测试的结果为:

从结果看出,id=1的数据需要修改,所以最新生成的List表中id为1的所有属性都是更改后的结果,而在list1中没有id为8的数据,说明这个是需要新增进去的一条记录,因此在最新的List也有了,这次主要用到自定义的比较器,去实现IEqualityComparer<>这个接口。另外还用到了Lambda表达式

var result = list2.Union(list1, new MyComparer());特别是Union这个方法的使用,该方法还有很多种用法,这里就举个例子而已啦。

更多精彩内容其他人还在看

C#抽象类与抽象方法详解

这篇文章主要为大家详细介绍了C#抽象类与抽象方法的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

C#代码实现扑克牌排序的几种方式

今天小编就为大家分享一篇关于C#代码实现扑克牌排序,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
收藏 0 赞 0 分享

C#泛型概念的简介与泛型的使用

今天小编就为大家分享一篇关于C#泛型概念的简介与泛型的使用,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
收藏 0 赞 0 分享

C# 7.0 使用下划线忽略使用的变量的原因分析

这篇文章主要介绍了C# 7.0 使用下划线忽略使用的变量的原因浅析,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

C# 中使用正则表达式匹配字符的含义

正则表达式的作用用来描述字符串的特征。本文重点给大家介绍C# 中使用正则表达式匹配字符的含义,非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧
收藏 0 赞 0 分享

C# Dictionary和SortedDictionary的简介

今天小编就为大家分享一篇关于C# Dictionary和SortedDictionary的简介,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
收藏 0 赞 0 分享

C#中SQL Command的基本用法

今天小编就为大家分享一篇关于C#中SQL Command的基本用法,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
收藏 0 赞 0 分享

C#使用SQL DataReader访问数据的优点和实例

今天小编就为大家分享一篇关于C#使用SQL DataReader访问数据的优点和实例,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
收藏 0 赞 0 分享

C#使用SQL Dataset数据集代码实例

今天小编就为大家分享一篇关于的文章,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
收藏 0 赞 0 分享

C#使用SQL DataAdapter数据适配代码实例

今天小编就为大家分享一篇关于C#使用SQL DataAdapter数据适配代码实例,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
收藏 0 赞 0 分享
查看更多