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;
}