c# – 使用LINQ更新IEnumerable对象的简单方法
发布时间:2020-12-15 04:01:29 所属栏目:百科 来源:网络整理
导读:假设我有这样的业务对象, class Employee { public string name; public int id; public string desgination; public int grade; } ListEmployee lstEmp = new ListEmployee() { new Employee() { name="A",desgination="SE",id=1},new Employee() { name="b
假设我有这样的业务对象,
class Employee { public string name; public int id; public string desgination; public int grade; } List<Employee> lstEmp = new List<Employee>() { new Employee() { name="A",desgination="SE",id=1},new Employee() { name="b",desgination="TL",id=2},new Employee() { name="c",desgination="PL",id=3},new Employee() { name="d",id=4},new Employee() { name="e",desgination="SSE",id=5},}; 如果我想把员工年级更新为3,其名称为“SE”,那么我必须写这样的东西 lstEmp=lstEmp.Select(x => { x.grade = (x.desgination == "SE") ? 3 : x.grade; return x; }).ToList(); 但是在这里使用select时,它会每次都会生成新的employee对象,而不是更新现有的lstEmp,所以我必须将更新的列表重新发送到lstEmp. 在我看来,它会频繁地更新大型更新会影响性能.是否有解决方法? 解决方法
我相信默认的LINQ方法支持内联更新.但是您可以创建自己的扩展方法来实现
public static void Update<TSource>(this IEnumerable<TSource> outer,Action<TSource> updator) { foreach (var item in outer) { updator(item); } } 并像这样使用它 lstEmp.Update(x => x.grade = (x.desgination == "SE") ? 3 : x.grade); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |