泛型集合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
1 string[] temArr = { "Ha", "Hunter", "Tom", "Lily", "Jay", "Jim", "Kuku", "Locu" };
2 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 可以委托给一个函数或者一个拉姆达表达式
委托给拉姆达表达式:
1 string listFind = mList.Find( name => { if (name.Length > 3) { return true; } return false; } ); 2 Console.WriteLine(listFind); 3 //name是变量,代表的是mList 中元素,自己设定 4 //输出是Hunter
委托给一个函数:
1 string listFind = mList.Find( ListFind ); 2 Console.WriteLine(listFind); 3 public bool ListFind(string name) 4 { 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 中的每个元素都与指定的谓词所定义的条件相匹配
委托给拉姆达表达式:
1 bool flag = mList.TrueForAll(name => { if (name.Length > 3) { return true; } else { return false; } } ); 2 Console.WriteLine("True for all: "+flag); 3 //flag值为false
委托给一个函数:
1 bool flag = mList.TrueForAll( ListFind );
2 Console.WriteLine("True for all: "+flag); 3 //flag值为false 这两种方法的结果是一样的
List.FindAll方法:返回 List<T>
public List<T> FindAll(Predicate<T> match);
检索与指定谓词所定义的条件相匹配的所有元素
1 List<string> subList = mList.FindAll(ListFind); //委托给ListFind函数
2 foreach (string s in subList) { Console.WriteLine("element in subList: "+s); }
这时subList存储的就是所有长度大于3的元素
List.Take(n)方法: 返回List<T>
获得前n行 返回值为IEnumetable<T>,T的类型与List<T>的类型一样
1 IEnumerable<string> takeList= mList.Take(5);
2 foreach (string s in takeList) { Console.WriteLine("element in takeList: " + s); }
这时takeList存放的元素就是mList中的前5个
List.Where方法:返回List<T>
检索与指定谓词所定义的条件相匹配的所有元素
跟 List.FindAll 方法类似。
1 IEnumerable<string> whereList = mList.Where(name => { if (name.Length > 3) { return true; } else { return false; } }); 2 foreach (string s in subList) { Console.WriteLine("element in subList: "+s); }
这时subList存储的就是所有长度大于3的元素
List.RemoveAll方法:返回移除的数量
public int RemoveAll(Predicate<T> match);
移除与指定的谓词所定义的条件相匹配的所有元素。
1 mList.RemoveAll( name => { if (name.Length > 3) { return true; } else { return false; } } ); 2 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