List<T>类是 ArrayList 类的泛型等效类。该类使用大小可按需动态增加的数组实现 IList<T> 泛型接口。
泛型的好处: 它为使用c#语言编写面向对象程序增加了极大的效力和灵活性。不会强行对值类型进行装箱和拆箱,或对引用类型进行,向下强制类型转换,所以性能得到提高。
性能注意事项: List[T]两点优势
(1)在决定使用IList<T> 还是使用ArrayList类(两者具有类似的功能)时,记住IList<T> 类在大多数情况下执行得更好并且是类型安全的。
(2)如果对IList<T> 类的类型 T 使用引用类型,则两个类的行为是完全相同的。但是,如果对类型 T 使用值类型,则需要考虑实现和装箱问题。
添加到ArrayList 中的任何引用或值类型都将隐式地向上强制转换为Object。如果项是值类型,则必须在将其添加到列表中时进行装箱操作,在检索时进行取消装箱操作。强制转换以及装箱和取消装箱操作都会降低性能;在必须对大型集合进行循环访问的情况下,装箱和取消装箱的影响非常明显。---微软
1.添加元素
(1)List. Add(T item) 添加一个元素,E.g.: mList.Add("John");
(2)List. AddRange(IEnumerable<T>collection) 添加一组元素,
E.g.: string[] temArr = { "Ha","Hunter", "Tom","Lily", "Jay","Jim", "Kuku", "Locu"};
mList.AddRange(temArr);
(3)在index位置添加一个元素, E.g.: mList.Insert(1, "Hei");
2.删除元素
(1)删除一个值,E.g.: mList.Remove("Hunter");
(2)删除下标为index的元素,E.g.: mList.RemoveAt(0);
(3)从下标index开始,删除count个元素, E.g.: mList.RemoveRange(3, 2);
3.排序元素
(1)默认是元素第一个字母按升序,E.g.: mList.Sort();
(2)顺序反转,E.g.:List. Reverse () ;可以与List. Sort ()配合使用,达到想要的效果
4.查找元素
(1)List.Find 方法:搜索与指定谓词所定义的条件相匹配的元素,并返回整个 List 中的第一个匹配元素。
Predicate是对方法的委托,如果传递给它的对象与委托中定义的条件匹配,则该方法返回 true。当前 List 的元素被逐个传递给Predicate委托,并在 List 中向前移动,从第一个元素开始,到最后一个元素结束。当找到匹配项时处理即停止。
public T Find(Predicate<T>match);
List.FindLast 方法:搜索与指定谓词所定义的条件相匹配的元素,并返回整个 List 中的最后一个匹配元素。
(2)List.TrueForAll方法: 确定是否 List 中的每个元素都与指定的谓词所定义的条件相匹配。
publicbool TrueForAll(Predicate<T> match);
(3)List.FindAll方法:检索与指定谓词所定义的条件相匹配的所有元素。
publicList<T>FindAll(Predicate<T> match);
(4)List.Where方法:检索与指定谓词所定义的条件相匹配的所有元素。跟List.FindAll方法类似。
(5)List.RemoveAll方法:移除与指定的谓词所定义的条件相匹配的所有元素。