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

publicclassList<T> : IList<T>,ICollection<T>, IEnumerable<T>, IList,ICollection, IEnumerable

List<T>类是 ArrayList 类的泛型等效类。该类使用大小可按需动态增加的数组实现 IList<T> 泛型接口。

泛型的好处: 它为使用c#语言编写面向对象程序增加了极大的效力和灵活性。不会强行对值类型进行装箱和拆箱,或对引用类型进行

向下强制类型转换,所以性能得到提高。

性能注意事项:

在决定使用IList<T> 还是使用ArrayList类(两者具有类似的功能)时,记住IList<T> 类在大多数情况下执行得更好并且是类型安全

的。

如果对IList<T> 类的类型 T 使用引用类型,则两个类的行为是完全相同的。但是,如果对类型 T 使用值类型,则需要考虑实现和装

箱问题。

用微软的话讲:

“添加到ArrayList 中的任何引用或值类型都将隐式地向上强制转换为Object。如果项是值类型,则必须在将其添加到列表中时进行装

箱操作,在检索时进行取消装箱操作。强制转换以及装箱和取消装箱操作都会降低性能;在必须对大型集合进行循环访问的情况下,装

箱和取消装箱的影响非常明显。”

1、  List的基础、常用方法:

声明:

1、List<T> mList = newList<T>();

T为列表中元素类型,现在以string类型作为例子

E.g.: List<string> mList= newList<string>();

2、  List<T>testList =new List<T> (IEnumerable<T>collection);

以一个集合作为参数创建List

E.g.:

string[] temArr = { "Ha","Hunter", "Tom","Lily", "Jay","Jim", "Kuku","Locu" };

List<string>testList = newList<string>(temArr);

添加元素:

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、Insert(int index, T item);    在index位置添加一个元素

E.g.:    mList.Insert(1, "Hei");

遍历List中元素:

foreach (T element in mList)  T的类型与mList声明时一样

{

Console.WriteLine(element);

}

E.g.:

foreach (string s in mList)

{

Console.WriteLine(s);

}

删除元素:

1、 List. Remove(T item)       删除一个值

E.g.:   mList.Remove("Hunter");

2、 List. RemoveAt(intindex);   删除下标为index的元素

E.g.:   mList.RemoveAt(0);

3、 List. RemoveRange(intindex, int count);

从下标index开始,删除count个元素

E.g.:   mList.RemoveRange(3, 2);

判断某个元素是否在该List中:

List. Contains(T item)   返回true或false,很实用

E.g.:

if (mList.Contains("Hunter"))

{

Console.WriteLine("There is Hunter in the list");

}

else

{

mList.Add("Hunter");

Console.WriteLine("Add Hunter successfully.");

}

给List里面元素排序:

List. Sort ()   默认是元素第一个字母按升序

E.g.:   mList.Sort();

给List里面元素顺序反转:

List. Reverse ()   可以与List. Sort ()配合使用,达到想要的效果

E.g.:   mList.Sort();

List清空:List. Clear ()

E.g.:   mList.Clear();

获得List中元素数目:

List. Count ()    返回int值

E.g.:

int count = mList.Count();

Console.WriteLine("The num of elements in the list: "+count);

2、  List的进阶、强大方法:

举例用的List:

string[] temArr = { Ha","Hunter", "Tom","Lily", "Jay","Jim", "Kuku",""Locu"};

mList.AddRange(temArr);

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

public T Find(Predicate<T>match);

Predicate是对方法的委托,如果传递给它的对象与委托中定义的条件匹配,则该方法返回 true。当前 List 的元素被逐个传递给

Predicate委托,并在 List 中向前移动,从第一个元素开始,到最后一个元素结束。当找到匹配项时处理即停止。

Predicate可以委托给一个函数或者一个拉姆达表达式

委托给拉姆达表达式:

E.g.:

stringlistFind = mList.Find(name =>  //name是变量,代表的是mList

{                              //中元素,自己设定

if(name.Length > 3)                {

returntrue;

}

returnfalse;

});

Console.WriteLine(listFind);     //输出是Hunter

委托给一个函数:

E.g.:

string listFind1 = mList.Find(ListFind);   //委托给ListFind函数

Console.WriteLine(listFind);           //输出是Hunter

ListFind函数:

public bool ListFind(string name)

{

if(name.Length > 3)

{

returntrue;

}

returnfalse;

}

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

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

public T FindLast(Predicate<T>match);

用法与List.Find相同。

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

publicbool TrueForAll(Predicate<T> match);

委托给拉姆达表达式:

E.g.:

bool flag= mList.TrueForAll(name =>

{

if(name.Length > 3)

{

returntrue;

}

else

{

returnfalse;

}

}

);

Console.WriteLine("True for all: "+flag);  //flag值为false

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

E.g.:

bool flag = mList.TrueForAll(ListFind); //委托给ListFind函数

Console.WriteLine("True forall:  "+flag);  //flag值为false

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

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

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

E.g.:

List<string> subList =mList.FindAll(ListFind); //委托给ListFind函数

foreach (string s in subList)

{

Console.WriteLine("element in subList: "+s);

}

这时subList存储的就是所有长度大于3的元素

List.Take(n):  获得前n行 返回值为IEnumetable<T>,T的类型与List<T>的类型一样

E.g.:

IEnumerable<string>takeList=  mList.Take(5);

foreach(string s intakeList)

{

Console.WriteLine("element in takeList: " + s);

}

这时takeList存放的元素就是mList中的前5个

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

E.g.:

IEnumerable<string> whereList = mList.Where(name =>

{

if(name.Length > 3)

{

returntrue;

}

else

{

returnfalse;

}

});

foreach (string s in subList)

{

Console.WriteLine("element in subList: "+s);

}

这时subList存储的就是所有长度大于3的元素

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

publicint RemoveAll(Predicate<T> match);

E.g.:

mList.RemoveAll(name =>

{

if(name.Length > 3)

{

returntrue;

}

else

{

returnfalse;

}

});

foreach (string s in mList)

{

Console.WriteLine("element in mList:     " + s);

}

这时mList存储的就是移除长度大于3之后的元素。

[转]C# List<T>的详细用法的更多相关文章

  1. C#播放声音的四种方法 +AxWindowsMediaPlayer的详细用法

    C#播放声音的四种方法 第一种是利用DirectX 1.安装了DirectX SDK(有9个DLL文件).这里我们只用到MicroSoft.DirectX.dll和 Microsoft.Directx ...

  2. 在DOS下的DEBUG命令的详细用法

    在DOS下的DEBUG命令的详细用法 名称 解释 格式 a (Assemble) 逐行汇编 a [address] c (Compare) 比较两内存块 c range address d (Dump ...

  3. __declspec关键字详细用法

    __declspec关键字详细用法 __declspec用于指定所给定类型的实例的与Microsoft相关的存储方式.其它的有关存储方式的修饰符如static与extern等是C和C++语言的ANSI ...

  4. CString.Format的详细用法(转)

    CString.Format的详细用法(转) 在MFC程序中,使用CString来处理字符串是一个很不错的选择.CString既可以处理Unicode标准的字符串,也可以处理ANSI标准的字符串.CS ...

  5. IFRAM的详细用法

    IFRAM的详细用法:   IFRAM的详细用法:  <IFRAME>用于设置文本或图形的浮动图文框或容器. BORDER <IFRAME BORDER="3"& ...

  6. 【转】java.util.vector中的vector的详细用法

    [转]java.util.vector中的vector的详细用法 ArrayList会比Vector快,他是非同步的,如果设计涉及到多线程,还是用Vector比较好一些 import java.uti ...

  7. DOM Style样式对象的详细用法

    DOM Style样式对象的详细用法 HTML Style样式比较复杂,相应访问.修改方法也有所差异.参考相关资料,整理如下. 典型Html文件如下,有三种定义方式. <head>     ...

  8. css基础之 font的简写规则 以及 自定义 CSS3 @font-face详细用法

    Part 1 font简写 CSS的命名规则是用英文字母 数字 和下划线(一般用小写)来命名.简写css font的好处有三:一是写起来方便(就像键盘快捷键):二是简化代码:三是帮助你熟悉和深刻理解c ...

  9. Tomcat详细用法学习(三)

    本篇接上一篇<Tomcat详细用法学习(二)>,主要讲解服务器所要求的web应用的组织结构. 上一篇说到了如何使用服务器将自己的web应用映射成虚拟目录,以便于在浏览器中可以对自己开发的w ...

  10. Tomcat详细用法学习(五)

    本篇接上一篇<Tomcat详细用法学习(四)>,主要讲解Tomcat服务器的管理平台 我们可能会将很多web应用交给Tomcat,那么Tomcat服务器就要对我们这些载入的web应用进行管 ...

随机推荐

  1. beta阶段事后诸葛亮会议

    项目名:约跑 组名:nice! 组长:李权 组员: 韩媛媛 于淼 刘芳芳 宫丽君 Beta Review会议 时间:2016.11.15 地点:冬华楼一楼大厅 会议内容: 约跑APP的Beta Rev ...

  2. RobotFramework 安装配置(一)

    服务器接口的测试框架的选择,最后选中了 RobotFramework ,原因一:能有效的管理测试用例,,支持批量执行,能实现关键字驱动或者数据驱动.原因二:支持测试人员可以使用Python和java创 ...

  3. 【sublime】在终端下手动安装sublime text 2

    Sublime2下载地址:http://www.sublimetext.com/download step.1 解压下载的压缩包 tar xf Sublime\ Text\ 2.0.2.tar.bz2 ...

  4. wc移植sae笔记

    1.wc移植到sae---上传图片 ①先看profile.ptl.html中的ajax代码修改functions.js中G_BASE_URL的值.在这里我先写死成->'http://2.idan ...

  5. xcode简介

    Xcode 是苹果公司开发的编程软件,是开发人员建立OS X 和 iOS 应用程序的最快捷方式.Xcode 具有统一的用户界面设计,编码.测试.调试都在一个简单的窗口内完成. Xcode前身是继承自N ...

  6. 视频处理控件TVideoGrabber如何对屏幕进行录制/压缩

    TVideoGrabber可以对屏幕进行录制和压缩,本文来详细的说明在多种情况下TVideoGrabber是如何实现屏幕的录制和压缩. 屏幕录制 当VideoSource = vs_ScreenRec ...

  7. 基于mjpg_streamer视频服务器移植【转】

    本文转载自:http://blog.csdn.net/wavemcu/article/details/7539560 MJPG简介: MJPG是MJPEG的缩写,但是MJPEG还可以表示文件格式扩展名 ...

  8. js 如何生成唯一且不可预测的 ID

    通常数据库可以生成唯一的 ID,最多的就是数字序列,也有像 MongoDB 这样产生组合序列的,不过这种形式的 ID 由于是序列,是可以预测的.如果想得到不可预测且唯一的 ID,方法还是有的. 下面主 ...

  9. 测试驱动开发神器框架Mockito

    作为菜鸟的我,以前没接触过Mock类型的框架,比如说要测试action层,我总是从action层调用service再调用dao访问数据库,这种方式从原则上来说是无疑是非常正确的,在没用mock框架之前 ...

  10. rsync增量传输大文件优化技巧

    问题 rsync用来同步数据非常的好用,特别是增量同步.但是有一种情况如果不增加特定的参数就不是很好用了.比如你要同步多个几十个G的文件,然后网络突然断开了一下,这时候你重新启动增量同步.但是发现等了 ...