如何解决从ID的通用列表中删除对象
| 我有一个像这样的领域类:public class DomainClass
{
public virtual string name{get;set;}
public virtual IList<Note> Notes{get;set;}
}
我要如何从ѭ1中取出物品?如果它是一个列表,我将能够做到,但是当我在持久层中使用Nhibernate时,它必须是2英镑。
理想情况下,我在域类中需要这样的方法:
public virtual void RemoveNote(int id)
{
//remove the note from the list here
List<Note> notes = (List<Note>)Notes
notes.RemoveAll(delegate (Note note)
{
return (note.Id = id)
});
}
但是我不能把IList
ѭList
。有没有更优雅的方式来解决这个问题?
解决方法
您可以过滤掉不需要的项目,并仅使用需要的项目创建一个新列表:
public virtual void RemoveNote(int id)
{
//remove the note from the list here
Notes = Notes.Where(note => note.Id != id).ToList();
}
, Edit2:此方法不需要强制转换为ѭ5!
foreach (var n in Notes.Where(note => note.Id == id).ToArray()) Notes.Remove(n);
要么...
Notes.Remove(Notes.Where(note => note.Id == id).First());
第一个是最好的。
如果没有音符带有ѭ10,第二个将引发异常。
编辑:感谢马格努斯和rsbarro显示我的错误。
, 如果可以更改数据结构,建议使用Dictionary
。比您可以使用的:
public class DomainClass
{
public virtual string name{get;set;}
public virtual IDictionary<int,Note> Notes {get; set;}
//Helper property to get the notes in the dictionary
public IEnumerable<Note> AllNotes
{
get
{
return notes.Select (n => n.Value);
}
}
public virtual void RemoveNote(int id)
{
Notes.Remove(id);
}
}
如果ID不是唯一的,请改用IDictionary<int,IList<Note>>
。
, 您可以手动编码。天真的实现是O(n * k),列表中的项数为n,要删除的项数为k。如果您只想删除单个项目,那就快了。
但是,如果您要删除很多项,那么对于许多IList<T>
的实现(包括ѭ16idea,则不知道NHibernate列表的行为),本机实现会变成ѭ14need,并且您需要编写更多代码才能获得O(n)
RemoveAll
的实现。
旧答案的一种可能实现:列出,而不丢失参考
此实现的技巧是将保留的项目移动到O(n)中列表的开头。然后,它会继续删除列表的最后一项(由于不需要移动元素,因此通常为O(1)),因此截断总计为O(n)。这意味着整个算法为O(n)。
, 请考虑,在某些情况下最好避免使用公共虚拟,以这种方式使用模板方法模式:
public void Load(IExecutionContext context)
{
// Can safely set properties,call methods,add events,etc...
this.Load(context);
// Can safely set properties,etc.
}
protected virtual void Load(IExecutionContext context)
{
}
, 您会收到一系列要删除的项目。比将它们从循环列表中删除。
看这个例子:
IList<int> list = new List<int> { 1,2,3,4,5,1,5 };
var valuesToRemove = list.Where(i => i == 1).ToArray();
foreach (var item in valuesToRemove)
{
list.Remove(item);
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。