C#中ListT用法

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

public classList<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 =newList<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 elementin mList)

T的类型与mList声明时一样

E.g.:
foreach (string sin 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方法:检索与指定谓词所定义的条件相匹配的所有元素。

public List<T>FindAll(Predicate<T> match);E.g.:List<string> subList =mList.FindAll(ListFind);//委托给ListFind函数foreach (string sin 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 sintakeList){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){return true;}else{return false;}});foreach (string sin subList){Console.WriteLine("element in subList: "+s);}这时subList存储的就是所有长度大于3的元素


 

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

public int RemoveAll(Predicate<T> match);E.g.:mList.RemoveAll(name =>{if(name.Length > 3){return true;}else{return false;}});foreach (string sin mList){Console.WriteLine("element in mList:    " + s);}这时mList存储的就是移除长度大于3之后的元素。


 

 

 

转载于:https://www.cnblogs.com/fifa0329/p/4536664.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/493993.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

算力超英伟达?华为推出两款“昇腾”芯片;五大AI战略正式公布

来源&#xff1a;AI科技大本营华为也像是要 All in AI 了。10 月 10 日&#xff0c;华为全联接大会 2018 上&#xff0c;华为轮值董事长徐直军带来了一系列的硬核 AI。在大会上&#xff0c;他系统公布了华为的 AI 发展战略&#xff0c;以及全栈全场景 AI 解决方案&#xff0c;其…

Qt5:渐变效果的实现

http://devbean.blog.51cto.com/448512/238168/ 转载于:https://www.cnblogs.com/wowk/p/3174602.html

React之JSX入门

React是由ReactJS与React Native组成&#xff0c;其中ReactJS是Facebook开源的一个前端框架&#xff0c;React Native 是ReactJS思想在native上的体现&#xff01; JSX并不是一门新的语言&#xff0c;仅仅是个语法糖&#xff0c;允许开发者在JavaScript中书写HTML语法。&…

英特尔人工智能副总裁:AI不是一种技能,而是一种对于工作的描述

来源&#xff1a;网络大数据人工智能领域的迅速发展&#xff0c;相关人才不能满足需求已经成为业界共识。有报道称&#xff0c;因为人工智能工程师庞大的缺口&#xff0c;一些公司为了获得人才不得不支付数百万美元的薪水。如何满足对人工智能工程师不断增长的招聘和培训的需求…

html 中表格长度固定

2010-02-03 14:25 1070人阅读 评论(0) 收藏 举报htmlclassxhtml产品bordertable<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"><html xmlns"http://www.w3.org/1999/xht…

React Native实例

本文主要包括以下内容 View组件的实例 Text组件实例 Navigator组件实例 TextInput组件实例 View组件的实例 效果如下 代码如下 /*** Sample React Native App* https://github.com/facebook/react-native* flow*/import React, { Component } from react; import {AppRe…

谷歌的硬件梦:Pixel手机、ChromeOS平板和Home音箱

来源&#xff1a; 网易智能&#xff08;北京时间10月9日23点&#xff09;&#xff0c;谷歌在纽约如期举行了主题为“谷歌制造”&#xff08;Made By Google&#xff09;的硬件发布会&#xff0c;推出了Pixel手机、平板 笔记本&#xff0c;以及音箱等一系列新品硬件。一个月以来…

浅用block 转

block是一门有用的大后期学问。现在我只是列出一点基本用法。 1.快速枚举&#xff08;Enumeration&#xff09; 通常是和NSArray, NSDictionary, NSSet, NSIndexSet放在一起用。 当和以上这两种东西放在一起用时&#xff0c;通常block有两种用处。&#xff08;代码为实例操作&a…

数据结构之图的实现

本文主要包括以下内容 邻接矩阵实现无向图 邻接表实现无向图 邻接矩阵实现有向图邻接表实现有向图 图的理论基础&#xff0c;请参考&#xff1a;图的理论基础 - 如果天空不死 - 博客园 邻接矩阵实现无向图 MatrixUDG是邻接矩阵对应的结构体。 mVexs用于保存顶点&#xf…

“万维网之父”发文阐述其下一个网络时代:将数据与应用分离,互联网去中心化正在路上...

来源&#xff1a;Deep Tech深科技关注“万维网之父”Tim Berners-Lee 动态的人&#xff0c;一定知道这位业内大神正在投身于下一代互联网的建设——一个去中心化的互联网。他正在领导其 MIT 团队搭建一个名为“ Solid ”&#xff08;Social Linked Data 社交关联数据&#xff0…

设置easyui input默认值

/*设置input 焦点*/ $(function () {//集体调用 $(".formTextBoxes input").each(function () {$(this).setDefauleValue();});//单个调用 $(".textkey").setDefauleValue(); })//设置input,textarea默认值 .之前写法$.fn.seDefauleValue function(){ $.f…

React Native官方DEMO

官方给我们提供了UIExplorer项目&#xff0c;这里边包含React Native的基本所有组件的使用介绍和方法。 运行官方DEMO步骤如下 安装react native环境 React Native项目源码下载下载安装cygwin软件 下载安装NDK然后安装以及配置 添加Node依赖模块:该命令行需要切到react-nati…

牛津教授揭秘AI革命及其前沿进展

来源&#xff1a;专知导读&#xff1a;2018年9月9日-14日&#xff0c;DeepMind主办的Deep Learning Indaba 2018大会在南非斯泰伦博斯举行。会上&#xff0c;牛津大学教授Nando de Freitas和其他15位专家做了《深度学习&#xff1a;AI革命及其前沿进展》的报告。报告导读&#…

【will】JS去字符串首尾空格

当IE不支持Jquery的Trim()方法时&#xff0c; 就需要JS的方法&#xff1a; function mytrim(str){return str.replace(/^\s|\s$/g,"");}转载于:https://www.cnblogs.com/EMTeam/p/3181471.html

数据结构之DFS与BFS实现

本文主要包括以下内容 邻接矩阵实现无向图的BFS与DFS 邻接表实现无向图的BFS与DFS 理论介绍 深度优先搜索介绍 图的深度优先搜索(Depth First Search)&#xff0c;和树的先序遍历比较类似。 它的思想&#xff1a;假设初始状态是图中所有顶点均未被访问&#xff0c;则从某…

一图分析华为最新AI生态与未来趋势

华为全联接大会2018年10月10日在上海召开&#xff0c;作为面向ICT产业的年度大会&#xff0c;华为公布了重要AI战略&#xff0c;将华为AI发展战略概括为以下五大方向&#xff1a;强力投资基础研究、打造全栈解决方案、投资开放生态和人才培养、解决方案增强以及内部效率提升。华…

SQL SERVER 与ACCESS、EXCEL的数据导入导出转换

* 说明&#xff1a;复制表(只复制结构,源表名&#xff1a;a 新表名&#xff1a;b) select * into b from a where 1<>1* 说明&#xff1a;拷贝表(拷贝数据,源表名&#xff1a;a 目标表名&#xff1a;b) insert into b(a, b, c) select d,e,f from b;* 说明&am…

数据结构之Dijkstra算法

基本思想 通过Dijkstra计算图G中的最短路径时&#xff0c;需要指定起点s(即从顶点s开始计算)。 此外&#xff0c;引进两个集合S和U。S的作用是记录已求出最短路径的顶点(以及相应的最短路径长度)&#xff0c;而U则是记录还未求出最短路径的顶点(以及该顶点到起点s的距离)。 …

在读博士的第八年,她破解了量子计算领域最基本的问题之一

来源&#xff1a;原理Urmila Mahadev&#xff08;厄米拉马哈德夫&#xff09;花了八年时间在研究生院解决了量子计算领域最基本的问题之一&#xff1a;怎么知道量子计算机是否做了量子计算呢&#xff1f;2017年春天&#xff0c;Urmila Mahadev发现自己处于大多数研究生都会认为…

页面加载完时再动态添加脚步

//页面加载时不存在&#xff0c;加载完时再添加 function loadScript(url) {//外部文件var script document.createElement("script");script.type "text/javascript";script.src url;document.body.appendChild(script); }function loadScriptString(c…