zoukankan      html  css  js  c++  java
  • C# List<T>的详细用法

    所属命名空间:System.Collections.Generic    

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

    委托给拉姆达表达式:

    E.g.:

       

     1  stringlistFind = mList.Find(name =>  )//name是变量,代表的是mList
     2 
     3             {                              //中元素,自己设定
     4 
     5                 if(name.Length > 3)            
     6               {
     7                     returntrue;
     8                 }
     9 
    10                 returnfalse;
    11 
    12             };
    13 
    14  
    15 
    16            Console.WriteLine(listFind);     //输出是Hunter

    委托给一个函数

     1 string listFind1 = mList.Find(ListFind);   //委托给ListFind函数
     2 Console.WriteLine(listFind);           //输出是Hunter
     3 
     4 //ListFind函数:
     5 public bool ListFind(string name)
     6         {
     7             if(name.Length > 3)
     8             {
     9                 returntrue;
    10             }
    11             returnfalse;
    12          }

    这两种方法的结果是一样的。

    List.FindLast 方法:搜索与指定谓词所定义的条件相匹配的元素,并返回整个 List 中的最后一个匹配元素。

    (2)List.TrueForAll方法:  确定是否 List 中的每个元素都与指定的谓词所定义的条件相匹配

    publicbool TrueForAll(Predicate<T> match);

    委托给拉姆达表达式:

     1 bool flag=mList.TrueForAll(name=>)
     2 {
     3 if (name.Length>3)
     4 {
     5 return true;
     6 }
     7 else
     8 {
     9 return false;
    10 }
    11 }
    12 Console.WriteLine("True for all:"+flag);//flag 的值为False

    委托给一个函数,这里用到上面的ListFind函数:

    1 bool flag = mList.TrueForAll(ListFind); //委托给ListFind函数
    2 Console.WriteLine("True forall:  "+flag);  //flag值为false

    (3)List.FindAll方法:检索与指定谓词所定义的条件相匹配的所有元素。

    publicList<T>FindAll(Predicate<T> match);

     1 E.g.:
     2 
     3 List<string> subList =mList.FindAll(ListFind); //委托给ListFind函数
     4 
     5         foreach (string s in subList)
     6 
     7         {
     8 
     9             Console.WriteLine("element in subList: "+s);
    10 
    11         }
    12 
    13         //这时subList存储的就是所有长度大于3的元素
    14 
    15 //List.Take(n):  获得前n行 返回值为IEnumetable<T>,T的类型与List<T>的类//型一样
    16 
    17 E.g.:
    18 
    19 IEnumerable<string>takeList=  mList.Take(5);
    20 
    21           foreach(string s intakeList)
    22 
    23           {
    24 
    25               Console.WriteLine("element in takeList: " + s);
    26 
    27           }
    28 
    29      //  这时takeList存放的元素就是mList中的前5个

    (3)List.Where方法:检索与指定谓词所定义的条件相匹配的所有元素。跟List.FindAll方法类似。

    (4)List.RemoveAll方法:移除与指定的谓词所定义的条件相匹配的所有元素。

  • 相关阅读:
    RabbitMqBase消息队列小结
    PtrSwap不仅仅是原地交换两个数
    InterfaceSummary接口小结
    InterfaceDesign接口设计原则
    InitOrder初始化执行顺序
    golang面向对象编程思想
    golang之工厂模式
    golang之方法
    golang之结构体使用注意事项和细节
    golang之匿名函数结合defer
  • 原文地址:https://www.cnblogs.com/AdaLoong/p/5528917.html
Copyright © 2011-2022 走看看