一次项目有这样的需求,本地存储了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{ 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 list1 = new List () { 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 list2 = new List () { 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这个方法的使用,该方法还有很多种用法,这里就举个例子而已啦
源码下载地址为: