List< T>RemoveAll()不删除项

本文关键字:删除 RemoveAll List | 更新日期: 2023-09-27 18:18:29

我有一个像这样的对象:

{
  "Text" : "Another lovely alert",
  "Category" : 2,
  "UserAlerts" : [{ "UserId" : 2 }]
}

传递给web API并正确绑定到:

[Key, Column(Order = 0)]
public long UserId { get; set; }
[Key, Column(Order = 1)]
public Guid AlertId { get; set; }
public virtual User User { get; set; }
public virtual Alert Alert { get; set; }

然后运行下面的代码,期望删除ID为2的UserAlert,但是对象没有改变。

alert.UserAlerts.ToList().RemoveAll(x => userIds.Contains(x.UserId));
alert.UserAlerts.ToList().RemoveAll(x => x.UserId == 2);

第二个查询更简单,但它也不做任何事情。我不知道我哪里出错了。

List< T>RemoveAll()不删除项

这是因为通过使用ToList,您正在创建新的列表对象,然后从它中删除项目,而不是从原始IEnumerable。

试着用这个:

alert.UserAlerts = alert.UserAlerts.Where(x => x.UserId != 2);

你不能在IEnumerable上运行RemoveAll,所以我认为在这里使用Linq是一个好主意。你将拥有不具有UserId=2的物品集合,这相当于移除所有具有UserId=2的物品。你需要从RemoveAll反转你的查询,它将在任何情况下工作。

这当然应该删除元素,但我不知道你怎么注意到它是否已经删除了?

首先使用ToList()创建列表,然后调用RemoveAll()从列表中删除一些元素,但由于您没有将该列表存储在任何地方,因此只需获取删除的项数。

您必须在alert.UserAlerts上调用RemoveAll,因为ToList创建了一个新的集合。
如果您删除该集合的所有项,则不会更改UserAlerts

alert.UserAlerts.RemoveAll(x => userIds.Contains(x.UserId));

更新:
如果UserAlerts不是List,则使用Where扩展方法(如wudzik在他的回答中所说):

alert.UserAlerts = alert.UserAlerts.Where(x => !userIds.Contains(x.UserId));