內容是別人勞動成果,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列表有變,產生異常!