集合之有序列表

如果需要基于键对所需集合排序,就可以使用SortedList<TKey,TValue>类。这个类按照键给元素排序。这个集合中的值和键都可以使用任意类型。

            //有序列表
            //SortedList<TKey,TValue>类只允许每个键有一个对应的值
            //SortedDictionary<TKey,TValue>的元素插入和删除操作比较快,SortedList<TKey,TValue>使用内存比较少
            var books = new SortedList<string, string>();
            books.Add("Test2", "2");
            books["Test3"] = "3";
            books["Test4"] = "4";
            foreach (var item in books)
            {
                Console.WriteLine($"{item.Key},{item.Value}");
            }
            foreach (var item in books.Keys)
            {
                Console.WriteLine($"{item}");
            }
            foreach (var item in books.Values)
            {
                Console.WriteLine($"{item}");
            }
            //LookUp<TKey,TElement>类每个键对应多个值
            List<Book> booklist = new List<Book>
            {
             new Book(1, ".net程序员的成长之路"),
             new Book(1, ".net程序员的转行之路"),
             new Book(2, "程序员的自我修养")
            };
            ILookup<int, string> looks = booklist.ToLookup(m => m.ID, m => { return "编号:" + m.ID + ";书名:" + m.BookName; });
            foreach (var item in looks)
            {
                Console.WriteLine(item.Key);
                foreach (var it in item)
                {
                    Console.WriteLine(it);
                }
            }
            var looksNew = booklist.ToLookup(m => m.ID);
            foreach (var item in looksNew)
            {
                Console.WriteLine("编号:" + item.Key);
                foreach (var its in item)
                {
                    Console.WriteLine(its.BookName);
                }
            }
            Console.ReadLine();

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

双叶红于二月花

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值