一、list简介
所属命名空间:system.collections.generic
public class list<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 的基础、常用方法:
声明:
list<t> mlist = new list<t>(); //t为列表中元素类型,现在以string类型作为例子 list<string> mlist = new list<string>();
list<t> testlist =new list<t> (ienumerable<t> collection); //以一个集合作为参数创建list string[] temarr = { "ha", "hunter",}; list<string> testlist = new list<string>(temarr);
添加元素:
遍历list中元素:
foreach (t element in mlist) t的类型与mlist声明时一样 { console.writeline(element); }
删除元素:
判断某个元素是否在该list中:list. contains(t item) 返回true或false,很实用
给list里面元素排序:list. sort () 默认是元素第一个字母按升序
给list里面元素顺序反转:list. reverse () 可以与list. sort ()配合使用,达到想要的效果
list清空:list. clear ()
获得list中元素数目:list. count () 返回int值
sortedlist类表示由键排序,并且通过键和索引访问键- 值对的集合。
一个排序列表是一个数组,哈希表的组合。它包含可使用键或索引来访问的项目的列表。如果使用一个索引访问项目,这是一个arraylist,如果使用一键访问项目,这是一个hashtable。集合的项总是由键值排序。
sortedlist类的方法和属性
下表列出了一些排序列表类的常用属性:
属性 | 描述 |
capacity | 获取或设置排序列表的容量 |
count | 获取包含在排序列表元素的数量 |
isfixedsize | 获取一个值,指示排序列表是否具有固定大小 |
isreadonly | 获取一个值,指示排序列表是否为只读 |
item | 获取并设置与sorddead列表中的特定键相关联的值 |
keys | 获取的排序列表的键 |
values | 获取的排序列表(sortedlist)中的值 |
下表列出了一些排序列表(sortedlist)类的常用方法:
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对移动技术网的支持。如果你想了解更多相关内容请查看下面相关链接
如对本文有疑问, 点击进行留言回复!!
使用Visual Studio2019创建C#项目(窗体应用程序、控制台应用程序、Web应用程序)
C#实现获取本地内网(局域网)和外网(公网)IP地址的方法分析
网友评论