c#刪除 list中的元素

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

發佈了11 篇原創文章 · 獲贊 3 · 訪問量 33萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章