内容是别人劳动成果,hl3292收集
1.这个我是用反循环来弄的。
for (int i = list.Count - 1; i >= 0; i--) { if (list[i].NO == item.NO) { list.RemoveAt(i); } }
网友评论:
用RemoveAll效率应该可以,他相当于一次遍历,把所有符合条件的元素都交换到List的前面,
然后一次性删除掉后面不符合条件的元素,效率是O(n)的,
如果是一条一条删,每删除一条之后都要把后面所有元素向前移动,效率是n^2的!
2.不过如果用其它list的话,其实也不用重现Clone方法
代码
public void RemoveItemFromList(ref List <A> list, A item) { List <A> tempList = new List <A>(); foreach (A a in list) { if (a.NO != item.NO && !tempList.Contains(a)) tempList.Add(a); } list = tempList; }
这样也可以。
如果在foreach里删除的话,这个时候还在遍历,会导致list列表有变,产生异常!