您好,欢迎访问一九零五行业门户网

C# List<T>的用法小结

所属命名空间:system.collections.generic
public class list8742468051c85b06f0a0af9e3e506b5c : ilist8742468051c85b06f0a0af9e3e506b5c, icollection8742468051c85b06f0a0af9e3e506b5c, ienumerable8742468051c85b06f0a0af9e3e506b5c, ilist, icollection, ienumerable
list8742468051c85b06f0a0af9e3e506b5c类是 arraylist 类的泛型等效类。该类使用大小可按需动态增加的数组实现 ilist8742468051c85b06f0a0af9e3e506b5c 泛型接口。
泛型的好处: 它为使用c#语言编写面向对象程序增加了极大的效力和灵活性。不会强行对值类型进行装箱和拆箱,或对引用类型进行向下强制类型转换,所以性能得到提高。
性能注意事项:
在决定使用ilist8742468051c85b06f0a0af9e3e506b5c 还是使用arraylist类(两者具有类似的功能)时,记住ilist8742468051c85b06f0a0af9e3e506b5c 类在大多数情况下执行得更好并且是类型安全的。
如果对ilist8742468051c85b06f0a0af9e3e506b5c 类的类型 t 使用引用类型,则两个类的行为是完全相同的。但是,如果对类型 t 使用值类型,则需要考虑实现和装箱问题。
“添加到 arraylist 中的任何引用或值类型都将隐式地向上强制转换为 object。如果项是值类型,则必须在将其添加到列表中时进行装箱操作,在检索时进行取消装箱操作。强制转换以及装箱和取消装箱操作都会降低性能;在必须对大型集合进行循环访问的情况下,装箱和取消装箱的影响非常明显。”
1、list的基础、常用方法:
声明:
1、list8742468051c85b06f0a0af9e3e506b5c mlist = new list8742468051c85b06f0a0af9e3e506b5c();
t为列表中元素类型,现在以string类型作为例子
e.g.:list98c455a79ddfebb79781bff588e7b37e mlist = new list98c455a79ddfebb79781bff588e7b37e();
2、list8742468051c85b06f0a0af9e3e506b5c testlist =new list8742468051c85b06f0a0af9e3e506b5c (ienumerable8742468051c85b06f0a0af9e3e506b5c collection);
以一个集合作为参数创建list
e.g.:
string[] temarr = { ha, hunter, tom, lily, jay, jim, kuku, locu };
list98c455a79ddfebb79781bff588e7b37e testlist = new list98c455a79ddfebb79781bff588e7b37e(temarr);
添加元素:
1、 list. add(t item)   添加一个元素
e.g.:mlist.add(john);
2、  list. addrange(ienumerable8742468051c85b06f0a0af9e3e506b5c 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(int index); 删除下标为index的元素
e.g.:mlist.removeat(0);
3、 list. removerange(int index, 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.:
string listfind = mlist.find(name => //name是变量,代表的是mlist { //中元素,自己设定 if (name.length > 3) { return true; } return false; }); 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) { return true; } return false; }
这两种方法的结果是一样的。
list.findlast 方法:搜索与指定谓词所定义的条件相匹配的元素,并返回整个 list 中的最后一个匹配元素。
public t findlast(predicate<t> match);
用法与list.find相同。
list.trueforall方法: 确定是否 list 中的每个元素都与指定的谓词所定义的条件相匹配。
public bool trueforall(predicate<t> match);
委托给拉姆达表达式:
e.g.:
bool flag = mlist.trueforall(name => { if (name.length > 3) { return true; } else { return false; } } ); console.writeline("true for all: "+flag); //flag值为false
委托给一个函数,这里用到上面的listfind函数:
e.g.:
bool flag = mlist.trueforall(listfind); //委托给listfind函数
console.writeline("true for all: "+flag); //flag值为false
这两种方法的结果是一样的。
list.findall方法:检索与指定谓词所定义的条件相匹配的所有元素。
public list<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 in takelist) { 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 s in 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 s in mlist) { console.writeline("element in mlist: " + s); }
这时mlist存储的就是移除长度大于3之后的元素。
list8742468051c85b06f0a0af9e3e506b5c 是一个泛型链表...t表示节点元素类型
比如
listbd43222e33876353aff11e13a7dc75f6 intlist;表示一个元素为int的链表
intlist.add(34); //添加
intlist.remove(34);//删除
intlist.removeat(0); //删除位于某处的元素
intlist.count; //链表长度
还有insert,find,findall,contains等方法,也有索引方法 intlist[0] = 23;
1.减少了装箱拆箱
2.便于编译时检查数据类型
lista87fdacec66f0909fc0757c19f2d2b1d 就相当于 system.collections命名空间里面的list
更多c# list8742468051c85b06f0a0af9e3e506b5c的用法小结。
其它类似信息

推荐信息