1 有关介绍
(1)所属命名空间:system.collections.generic
public class list<t> : ilist<t>, icollection<t>, ienumerable<t>, ilist, icollection, ienumerable.
(2)list<t>类是arraylist类的泛型等效类。该类使用大小可按需动态增加的数组实现ilist<t>泛型接口。
(3)泛型的好处: 它为使用c#语言编写面向对象程序增加了极大的效力和灵活性。不会强行对值类型进行装箱和拆箱,或对引用类型进行向下强制类型转换,所以性能得到提高。
(4) 性能注意事项:在决定使用 list<t> 还是使用 arraylist 类(两者具有类似的功能)时,记住 list<t> 类在大多数情况下执行得更好并且是类型安全的。
如果对 list<t> 类的类型 t 使用引用类型,则两个类的行为是完全相同的。但是,如果对类型 t 使用值类型,则需要考虑实现和装箱问题。
(5) 用微软的话讲:
“添加到 arraylist 中的任何引用或值类型都将隐式地向上强制转换为 object。如果项是值类型,则必须在将其添加到列表中时进行装箱操作,在检索时进行取消装箱操作。强制转换以及装箱和取消装箱操作都会降低性能;在必须对大型集合进行循环访问的情况下,装箱和取消装箱的影响非常明显。”
常用方法
1 声明:
(1)list<t> mlist = new list<t>();
t为列表中元素类型,现在以string类型作为例子
如: list<string> mlist = new list<string>();
(2)list<t> testlist =new list<t> (ienumerable<t> collection);
以一个集合作为参数创建list
string[] temarr = { ha, hunter, tom, lily, jay, jim, kuku, locu };
list<string> testlist = new list<string>(temarr);
2 添加元素:
(1) list. add(t item) 添加一个元素
mlist.add(john);
(2) list. addrange(ienumerable<t> collection) 添加一组元素
string[] temarr = { ha,hunter, tom, lily, jay, jim, kuku, locu };
mlist.addrange(temarr);
(3)insert(int index, t item); 在index位置添加一个元素
mlist.insert(1, hei);
遍历list中元素:
foreach (t element in mlist) t的类型与mlist声明时一样
{
console.writeline(element);
} 如下:
foreach (string s in mlist)
{
console.writeline(s);
}
2 删除元素
(1)list. remove(t item) 删除一个值
如: mlist.remove(hunter);
(2) list. removeat(int index); 删除下标为index的元素
如 mlist.removeat(0);
(3) list. removerange(int index, int count);
从下标index开始,删除count个元素
如 mlist.removerange(3, 2);
3判断某个元素是否在该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.);
}
更多介绍c# list<t>用法详解。