开发中,经常遇到List<obj>去重的问题,最普通的做法就是用2层循环滤过去重,比如以下方法:
if (req.Count > 1) { for (int i = 0; i < req.Count; i++) //外循环是循环的次数 { for (int j = req.Count - 1; j > i; j--) //内循环是 外循环一次比较的次数 { if ((req[i].addcs.org_schedule_id == req[j].addcs.org_schedule_id) && (req[i].addcs.org_course_type == req[j].addcs.org_course_type)) { req.RemoveAt(j); } } } }
自从有了LinQ和Lambda表达式后,这些方法都可以统统一句话搞定。比如:
//找一找教程网 http://www.zyiz.net/xilie-293.html List<AddCS> nonDuplicateList = req.Where((x, i) => req.FindLastIndex(z => z.addcs.org_schedule_id == x.addcs.org_schedule_id && z.addcs.org_course_type == x.addcs.org_course_type ) == i).ToList();//Lambda表达式去重
其中 FindLastIndex表示找重新项里的最后一个,若要找第一个,则为FindIndex