C#中List和SortedList的简介
一、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. add(t item) 添加一个元素
- list. addrange(ienumerable<t> collection) 添加一组元素
- insert(int index, t item); 在index位置添加一个元素
遍历list中元素:
foreach (t element in mlist) t的类型与mlist声明时一样 { console.writeline(element); }
删除元素:
- list. remove(t item) 删除一个值
- list. removeat(int index); 删除下标为index的元素
- list. removerange(int index, int count); 从下标index开始,删除count个元素
判断某个元素是否在该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)类的常用方法:
- void add( object key, object value ); 将带有指定键和值到排序列表的元素
- public virtual void clear(); 将删除sortedlist的所有元素
- public virtual bool containskey( object key ); 确定sortedlist 中是否包含一个特定的键
- public virtual bool containskey( object key ); 确定sortedlist 中是否包含一个特定的键
- public virtual bool containsvalue( object value ); 确定sortedlist 是否包含特定的值
- public virtual object getbyindex( int index ); 获取sortedlist中指定索引处的值
- public virtual object getkey( int index ); 获取sortedlist中指定索引处的键
- public virtual ilist getkeylist(); 获取sortedlist的键
- public virtual ilist getvaluelist(); 获取sortedlist中的值
- public virtual int indexofkey( object key ); 返回在排序列表中指定键从零开始的索引
- public virtual int indexofvalue( object value ); 返回在sortedlist中指定的值第一次出现的从零开始的索引
- public virtual void remove( object key ); 删除从sortedlist表中指定键的元素
- public virtual void removeat( int index ); 删除sortedlist中指定索引处的元素
- public virtual void trimtosize(); 设置在sortedlist元素的实际数量
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接