在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
开发中,经常遇到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 |
请发表评论