有序列表

有序列表

前言:如果需要基于键对所需集合排序。就可以使用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);
            }

 

    

posted @ 2017-11-16 09:45  丢了蜡笔小新会哭〆  阅读(399)  评论(0编辑  收藏  举报