• 有序列表


    有序列表

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

        

  • 相关阅读:
    Ruby 集合数组常用遍历方法
    Git,Github和Gitlab简介和基本使用
    L1-Day14
    学习进度(2)
    求数组的子数组的最大值(文件存储)
    开学第一课博客——自我介绍
    求数组的子数组的最大值
    学习进度(1)
    java web+模板
    android开发环境配置以及测试所遇到的的问题
  • 原文地址:https://www.cnblogs.com/MoRanQianXiao/p/7841208.html
Copyright © 2020-2023  润新知