当前位置: 移动技术网 > IT编程>开发语言>c# > C#中List和SortedList的简介

C#中List和SortedList的简介

2019年07月18日  | 移动技术网IT编程  | 我要评论

一、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元素的实际数量

总结

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

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网