欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

C#中List和SortedList的简介

程序员文章站 2023-12-05 21:39:22
一、list简介 所属命名空间:system.collections.generic  public class list : ilist&...

一、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);

添加元素:

  1. list. add(t item)   添加一个元素
  2. list. addrange(ienumerable<t> collection)   添加一组元素
  3. insert(int index, t item);    在index位置添加一个元素

遍历list中元素:

foreach (t element in mlist) t的类型与mlist声明时一样
 {
    console.writeline(element);
 }

删除元素:

  1. list. remove(t item)       删除一个值
  2. list. removeat(int index);   删除下标为index的元素
  3. 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元素的实际数量

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接