泛型集合List的详细用法
命名空间: System.Collections.Generic
List<T>类是 ArrayList 类的泛型等效类。
该类使用大小可 按需动态增加 的数组实现 IList<T> 泛型接口。
Enumerable 枚举
Collection 集合
泛型的好处:
它为使用c#语言编写面向对象程序增加了极大的效力和灵活性。
不会强行对值类型进行装箱和拆箱,或对引用类型进行向下强制类型转换,性能得到提高。
注意事项:
在决定使用IList<T> 还是使用ArrayList类(两者具有类似的功能)时,
记住IList<T> 类在大多数情况下执行得更好并且是类型安全的。
如果对IList<T> 类的类型 T 使用引用类型,则两个类的行为是完全相同的。
但是,如果对类型 T 使用值类型,则需要考虑实现和装箱问题。
List的基础、常用方法
声明:
List<T> NAME = new List<T>();
List<T> NAME =new List<T> (IEnumerable<T> collection); ----以一个集合作为参数创建List
string[] temArr = { "Ha", "Hunter", "Tom", "Lily", "Jay", "Jim", "Kuku", "Locu" };
List<string> testList = new List<string>(temArr);
添加元素:
List. Add(T item); ----添加一个元素
List. AddRange(IEnumerable<T> collection); ----添加一组元素
Insert(int index, T item); ----在index位置添加一个元素
遍历List中元素:
foreach (T element in mList); ----T的类型与mList声明时一样
删除元素:
List. Remove(T item); ----删除一个值
List. RemoveAt(int index); ----删除下标为index的元素
List. RemoveRange(int index, int count); ----从下标index开始,删除count个元素
注:删除某元素后,其后面的元素下标自动跟进
判断某个元素是否在该List中:
List. Contains(T item); ----返回true或false,很实用
if(mList.Contains("Hunter")){
Console.WriteLine("There is Hunter in the list");
} else {
mList.Add("Hunter");
Console.WriteLine("Add Hunter successfully.");
}
给List里面元素顺序反转: List. Reverse () 可以与List. Sort ()配合使用,达到想要的效果
List清空:
List.Clear ();
mList.Clear();
获得List中元素数目:
List.Count (); ----返回int值
List的进阶、强大方法
List.Find 方法:返回 T
搜索与指定谓词所定义的条件相匹配的元素,并返回整个 List 中的第一个匹配元素
public T Find(Predicate<T> match);
Predicate是对方法的委托,如果传递给它的对象与委托中定义的条件匹配,则该方法返回 true。
当前 List 的元素被逐个传递给Predicate委托,并在 List 中向前移动,从第一个元素开始,到最后一个元素结束。
当找到匹配项时处理即停止。
Predicate 可以委托给一个函数或者一个拉姆达表达式
委托给拉姆达表达式:
string listFind = mList.Find( name => { if (name.Length > 3) { return true; } return false; } );
Console.WriteLine(listFind);
//name是变量,代表的是mList 中元素,自己设定
//输出是Hunter
委托给一个函数:
string listFind = mList.Find( ListFind );
Console.WriteLine(listFind);
public bool ListFind(string name)
{ if (name.Length > 3) { return true; } return false; }
List.FindLast 方法:返回 T
public T FindLast(Predicate<T> match);
搜索与指定谓词所定义的条件相匹配的元素,并返回整个 List 中的最后一个匹配元素。用法与List.Find相同。
List.TrueForAll方法:返回 bool
public bool TrueForAll(Predicate<T> match);
确定是否 List 中的每个元素都与指定的谓词所定义的条件相匹配
委托给拉姆达表达式:
bool flag = mList.TrueForAll(name => { if (name.Length > 3) { return true; } else { return false; } } );
Console.WriteLine("True for all: "+flag);
//flag值为false
委托给一个函数:
bool flag = mList.TrueForAll( ListFind );
Console.WriteLine("True for all: "+flag); //flag值为false 这两种方法的结果是一样的
List.FindAll方法:返回 List<T>
public List<T> FindAll(Predicate<T> match);
检索与指定谓词所定义的条件相匹配的所有元素
List<string> subList = mList.FindAll(ListFind); //委托给ListFind函数
foreach (string s in subList) { Console.WriteLine("element in subList: "+s); }
这时subList存储的就是所有长度大于3的元素
List.Take(n)方法: 返回List<T>
获得前n行 返回值为IEnumetable<T>,T的类型与List<T>的类型一样
IEnumerable<string> takeList= mList.Take(5);
foreach (string s in takeList) { Console.WriteLine("element in takeList: " + s); }
这时takeList存放的元素就是mList中的前5个
List.Where方法:返回List<T>
检索与指定谓词所定义的条件相匹配的所有元素
跟 List.FindAll 方法类似。
IEnumerable<string> whereList = mList.Where(name => { if (name.Length > 3) { return true; } else { return false; } });
foreach (string s in subList) { Console.WriteLine("element in subList: "+s); }
这时subList存储的就是所有长度大于3的元素
List.RemoveAll方法:返回移除的数量
public int RemoveAll(Predicate<T> match);
移除与指定的谓词所定义的条件相匹配的所有元素。
mList.RemoveAll( name => { if (name.Length > 3) { return true; } else { return false; } } );
foreach (string s in mList) { Console.WriteLine("element in mList: " + s); }
这时mList存储的就是移除长度大于3之后的元素。
补充:
比如要实现一个int类型的动态二维数组。
要增加一行就matrix.add(new List<int>());
某行要增加数据就matrix[n].add(i); 但是不建议这么操作。
List<List<int>> matrix = new List<List<int>>();
matrix.Add(new List<int>()); matrix[0].Add(1);
Console.WriteLine(matrix[0][0]);
Console.ReadKey();
List与数组的相互转换
1.从string[]转List<string>
string[] str={“1”,”2”};
List <string> list=new List<string>(str);
2.从List<string>转string[]
List<String> listS=new List<String>();
listS.Add("str");
listS.Add("hello");
System.String[] str=listS.ToArray();
---------------------
原文链接:https://blog.csdn.net/jiong12/article/details/39638615
泛型集合List的详细用法的更多相关文章
- List 泛型 集合中 Find 的用法
以前在开发中为了对List,String[].Array进行元素的查找一般都是这样做:List lists = new List();list.add("111");.....fo ...
- C# List泛型集合中的GroupBy<>用法
//根据子项目id得到flowjump实体类 flowJumps = this.FlowJumps; //按工序groupby flowjumps IEnumerable<IGrouping&l ...
- 计算字符串中每种字符出现的次数[Dictionary<char,int>泛型集合用法]
有一道经典的面试题: 统计 welcome to china中每个字符出现的次数,不考虑大小写. 第一个出现在脑海里的想法是: 1. 将字字符串转换成 char数组: 2. 用 for循环遍 ...
- .NET中的泛型集合总结
最近对集合相关的命名空间比较感兴趣,以前也就用下List<T>, Dictionary<Tkey, TValue>之类,总之,比较小白.点开N多博客,MSDN,StackOve ...
- wpf 导出Excel Wpf Button 样式 wpf简单进度条 List泛型集合对象排序 C#集合
wpf 导出Excel 1 private void Button_Click_1(object sender, RoutedEventArgs e) 2 { 3 4 ExportDataGrid ...
- C#—类库、委托、is和as运算符、泛型集合
类库 类库(Class Library)是一个综合性的面向对象的可重用类型集合,这些类型包括:接口.抽象类和具体类.类库可以解决一系列常见编程任务(包括诸如字符串管理.数据收集.数据库连接以及文件访问 ...
- 编写高质量代码改善C#程序的157个建议[泛型集合、选择集合、集合的安全]
前言 软件开发过程中,不可避免会用到集合,C#中的集合表现为数组和若干集合类.不管是数组还是集合类,它们都有各自的优缺点.如何使用好集合是我们在开发过程中必须掌握的技巧.不要小看这些技巧,一旦在开 ...
- C#基础精华03(常用类库StringBuilder,List<T>泛型集合,Dictionary<K , V> 键值对集合,装箱拆箱)
常用类库StringBuilder StringBuilder高效的字符串操作 当大量进行字符串操作的时候,比如,很多次的字符串的拼接操作. String 对象是不可变的. 每次使用 System. ...
- 【转】java.util.vector中的vector的详细用法
[转]java.util.vector中的vector的详细用法 ArrayList会比Vector快,他是非同步的,如果设计涉及到多线程,还是用Vector比较好一些 import java.uti ...
随机推荐
- Dynamics365 WebAPI ADFS token 获取
public class CrmAuth { ///<summary> /// Token /// </summary> public string access_token ...
- yii的数据库相关操作
获取某一列数据 self::find()->where(['pid'=>$this->id])->select('id')->column(); 更新操作 $model- ...
- 爬虫下载QQ音乐:获取所有歌手-每个歌手的专辑-每个专辑里的歌曲
# coding=utf-8 # !/usr/bin/env python ''' author: dangxusheng desc : 稍微有点难度,需要多次请求获取key date : 2018- ...
- 如何修改运行中的docker容器的端口映射和挂载目录
在docker run创建并运行容器的时候,可以通过-p指定端口映射规则.但是,我们经常会遇到刚开始忘记设置端口映射或者设置错了需要修改.当docker start运行容器后并没有提供一个-p选项或设 ...
- MATLAB程序控制语句
Matlab中的程序控制语句包括条件控制(Conditional Control).循环(Loop Control).异常处理(Error Control)和程序返回(Program Terminat ...
- get请求02
import requests r = requests.get("http://www.baidu.com") print(r.status_code) #状态码 print(r ...
- Oracle 12.2报错ORA-15032、ORA-15410或ORA-15411解决
现象:在Oracle 12.2.0.1 RAC环境,在其ASM实例中,如果添加不同大小或者不同数量的LUN到failgroup中,会报错: ORA-15032: not all alterations ...
- PHP字符串格式化特点和漏洞利用点
转载至: https://www.anquanke.com/post/id/170850 PHP中的格式化字符串函数 在PHP中存在多个字符串格式化函数,分别是printf().sprintf().v ...
- 关于Ajax的认识和封装(小记)
一,Ajax 的概念 1,Ajax 是一种在无需重新加载整个网页(即刷新网页)的情况下,能够更新部分网页的技术. 2,Ajax 的全称是Asynchronous Javascript And XML” ...
- cookie小结
cookie的用处:当不同的用户访问同一家网站时(采用相同的请求地址),服务器如何区分不同用户的请求操作呢?需要浏览器对发出的每个请求进行标识.属于同一个会话的请求,都带有相同的标识,不同的会话带有不 ...