Lambda加自定义比较器实现两个列表的合并

一次项目有这样的需求,本地存储了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这个方法的使用,该方法还有很多种用法,这里就举个例子而已啦

源码下载地址为:http://files.cnblogs.com/xmfdsh/Lambda%E4%BB%A5%E5%8F%8A%E6%AF%94%E8%BE%83%E5%99%A8.zip

时间: 2024-10-05 23:25:13

Lambda加自定义比较器实现两个列表的合并的相关文章

python 如何在一个for循环中遍历两个列表

是我在看<笨方法学python>过程中发现有一行代码看不懂——“ for sentence in snippet, phrase:”,所以研究了半天,感觉挺有收获的.所以就放在博客上分享给大家了. 直入主题: 为了不耽误大家时间,如果知道以下为两段代码为什么输出不一样的话我觉得您肯定知道我下面要说的是什么了,您就不必花时间再读下去了. 1和2两段代码的区别是print在for循环中,另外一个是不在循环中.输出的结果却截然不同,如果想要弄懂如何遍历两列表,花些时间把下面的几行代码弄懂.我要说的您

Android 自定义 ListView 显示网络歌曲列表

本文内容 环境 项目结构 演示自定义 ListView 显示网络歌曲列表 参考资料 本文最开始看的一个国人的文章,没有源代码,根据文中提供的源代码,自己新建的项目(最可气的是,没有图标图片资源,只能自己乱编),但程序不是很稳定,有时能显示出列表中的缩略图,有时显示不出来,还在主线程访问了网络.后看文章评论,作者给出英文原文链接,本来想这下没事了吧,结果下载源代码运行后,还是有问题~仔细看英文原文,原来他也是根据 Github 上一个项目的基础上搞的,只是添加了式样,以及显示完整的歌曲列表,包括歌

EntityFramework Core 2.0自定义标量函数两种方式

前言 上一节我们讲完原始查询如何防止SQL注入问题同时并提供了几种方式.本节我们继续来讲讲EF Core 2.0中的新特性自定义标量函数. 自定义标量函数两种方式 在EF Core 2.0中我们可以将方法映射到数据库中的标量函数,我们可在LINQ中调用此方法并会被正确翻译成SQL语句,这为编写数据访问层的开发人员提供了一个很棒的功能来创建一个方法并在其上应用DbFunction特性即可.该属性会将静态CLR方法映射到数据库函数,以便可以在LINQ查询中使用此方法.默认情况下,数据库函数中的CLR

[Android] Android ViewPager 中加载 Fragment的两种方式 方式(二)

接上文: https://www.cnblogs.com/wukong1688/p/10693338.html Android ViewPager 中加载 Fragmenet的两种方式 方式(一) 二.使用Fragment来填充ViewPager Google 官方是建议我们使用Fragment来填充ViewPager的,这样可以更加方便的生成每个Page以及管理 每个Page的生命周期!当然它给我们提供了两个不同的Adapter,他们分别是: FragmentPageAdapter和Fragm

前面程序整合加自定义日志,日志会记录重目前还在找问题

前面程序整合加自定义日志 1.文件摆放 ├── xxxx │ ├── src.py │ └── fil_mode.py │ └── data_time.py │ └── loading.py │ └── data_time.py │ └── logger.py 2.运行文件 1.run src.py # 导入需要用到的所有内置模块 import logging import time import json import os from fil_mode import * from loadin

c#得出两个列表的交集

c#提供了Intersect来得到两个列表的交集,它是通过使用默认的相等比较器对值进行比较生成两个序列的交集,定义为: public static IEnumerable<TSource> Intersect<TSource>(this IEnumerable<TSource> first, IEnumerable<TSource> second); 我们使用它来比较两个列表试试: List<double> oneList = new List&

sort方法和自定义比较器的写法

摘要 在做一些算法题时常常会需要对数组.自定义对象.集合进行排序. 在java中对数组排序提供了Arrays.sort()方法,对集合排序提供Collections.sort()方法.对自定义对象排序时要自己重写比较器,对象数组则调用Arrays.sort(),对象集合则调用Collections.sort().两个方法默认都是升序,也可以重写比较器,实现降序. 对数组排序 sort函数模板, 以int型数组为例: Arrays.sort(int[] a, Comparator<Integer>

从自定义比较器(实现RawComparator接口的方式)总结的经验

在MR中我们在Map阶段的排序可是通过两种方式 要比较的值为key 1)实现WriteComparator接口---比较简单使用 2)自定义比较器(实现RawComparator接口) 这里我们介绍一下第二种方式 1.我们要自定义一个比较器实现RawComparator接口 2.重写方法 为什么有两个方法呢?追一下源码 RawComparator接口继承了Comparator,所以有两个方法 第一个方法中,我们可以有如下理解: 1.这个方法先被调用 2.在此方法中,将字节数组中的数据先封装成要比

1143. 两个列表的最小索引和

1143. 两个列表的最小索引和 中文English 假设Andy和Doris想要选择一家餐馆吃晚餐,他们都有一个各自最喜爱的餐馆列表. 你需要用最少的列表索引总和来帮助他们找出他们的共同兴趣. 如果最少列表索引总和的答案不唯一,则输出所有答案并且没有顺序要求. 你可以假设总有一个答案. 样例 案例 1: 输入: ["Shogun", "Tapioca Express", "Burger King", "KFC"] [&quo