有序列表
前言:如果需要基于键对所需集合排序。就可以使用SortedList<TKey,TValue>类。这个类按照键给元素排序。这个集合中的值和键都可以使用任意类型。
下面的例子创建了一个有序列表,其中的键和值都是string类型。默认的构造函数创建了一个空列表。在用Add()方法添加了两个名字。使用重载的构造函数,可以定义列表的容量。传递实现了IComparar<TKey>接口的对象。该接口用于给列表中的元素排序。
Add()方法的第一个参数是键(学号),第二个参数是值(学生的名字),索引器需要把键作为索引参数,如果键已经存在,Add()方法就会抛出一个异常。如果索引器使用相同的键,就会用新值替代旧值。
static void Main(string[] args) { //有序列表 SortedList<int, string> names = new SortedList<int, string>(); names.Add(1, "张三"); names.Add(2, "李四"); names.Add(5, "王五"); names.Add(3, "赵六"); names.Add(4, "田七"); foreach (KeyValuePair<int, string> keyValuePair in names) { Console.WriteLine("{0},{1}", keyValuePair.Key, keyValuePair.Value); } Console.ReadKey(); }
可以使用foreach 语句遍历该列表。枚举器返回的元素是KeyValuePair<int, string>,其中包含了键和值。键可以用Key属性访问。值可以用Value属性访问。
foreach (KeyValuePair<int, string> keyValuePair in names) { Console.WriteLine("{0},{1}", keyValuePair.Key, keyValuePair.Value); }
也可以使用Values和Keys属性访问值和键。因为Values属性返回的是IList<TValue>,Keys属性返回的是IList<TKey>,所以可以通过foreach语句使用这些属性:
foreach (int key in names.Keys) { Console.WriteLine(key); } foreach (string value in names.Values) { Console.WriteLine(value); }
如果尝试使用索引器访问一个元素,但是所传递的键不存在,就会抛出一个KeyNotFoundException类型的异常。为了避免这个异常。可以使用ContainsKey()方法 如果所传递的的键存在于这个集合中。这个方法就返回true,也可以调用TryGetValue()方法,该方法尝试获得指定键的值。如果指定键对应的值不存在,该方法就不会抛出异常。
string res; if (!names.TryGetValue(10, out res)) { Console.WriteLine("{0}对应的键没有被找到!!", 10); }