一次項目有這樣的需求,本地存儲了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