C#编程(五十二)----------有序列表
有序列表
如果需要基于对所有集合排序,就可以使用SortedList<TKey,TValue>类.这个类按照键给元素排序.这个集合中的值和键都可以使用任意类型.
下面的例子创建了一个有序列表,其中键和值类型都是string.默认的构造函数创建了一个空列表,再用Add()方法添加书.使用重载的构造函数.可以定义列表的容量,传递实现了IComparer<TKey>接口的对象,该接口用于给列表中的元素排序.
使用Add(Tkey,Tvalue)方法,第一个参数是键,第二个参数是值.除了使用Add()方法之外,还可以使用索引器添加元素到列表中.索引器需要把键作为索引参数.如果键已存在,Add()方法就抛出一个ArgumentException类型的异常.如果所引起使用相同的键,就用新值代替旧值.
SortedList<TKey,TValue>类只允许每个键有一个对应的值,如果需要每个键对应多个之,可以使用Lookup<TKey,TELement>类.
案例:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace 有序列表
{
class Program
{
static void Main(string[] args)
{
//如果要用排好顺序的表,可以使用SortedList<TKey,TValue>来给元素排序
SortedList<string, string> books = new SortedList<string, string>();
books.Add("tangseng", "001");
books.Add("sunwukong", "002");
books.Add("zhubajie", "003");
books.Add("shaheshang", "004");
//键是不允许重复,下面我们用Add方法重新添加一次tangseng
//books.Add("tangseng","hahah");抛出异常
//但是如果使用索引来赋值,如果键存在,则覆盖,不存在,相当于使用Add方法
books["tangseng"] = "hahaha";
foreach (var item in books.Keys)
{
Console.WriteLine(item);
}
foreach (var item in books.Values)
{
Console.WriteLine(item);
}
//一次性遍历键值
foreach (KeyValuePair<string, string> item in books)
{
Console.WriteLine("名字: {0} , 序号 : {1}", item.Key, item.Value);
}
/*
* 分析结果可知,tangseng被替换成了hahaha
*
* 下面简单介绍一下SortedList<TKey,TValue>中的方法与属性
* Capacity 这个属性用来设置与得到有序列表的容量,与IList一样,也时成倍增长的
* Comparer 返回与有序列表相关的比较器,可以从构造函数中传入该比较器
* Remove() RemoveAt() 按键删除与按索引删除
* ContainsKey();ContainsValue;检查是不是有包含指定值的键,或者值
* TryGetValue() 尝试获得指定键的值,如果有就是true,并用out把值带回来,没有就是false
*/
//按键删除
Console.WriteLine("按键删除");
books.Remove("tangseng");
foreach (KeyValuePair<string, string> item in books)
{
Console.WriteLine("名字 : {0}, 序号 : {1}", item.Key, item.Value);
}
//可以看出tangseng被删除了
//下面我们按索引删除
books.RemoveAt(0);
Console.WriteLine("按索引删除");
foreach (KeyValuePair<string, string> item in books)
{
Console.WriteLine("名字 : {0}, 序号 : {1}", item.Key, item.Value);
}
//结果中看出shaheshang被删除,证明删除索引是以排序后的顺序为准,不是以插入的顺序为准
//检查是否包含tangseng,检查是否包含zhubajie(键)
Console.WriteLine("检查是否包含tangseng: {0}", books.ContainsKey("tangseng"));
Console.WriteLine("检查是否包含zhubajie: {0}", books.ContainsKey("zhubajie"));
//检查是否包含001,检查是否包含002(值)
Console.WriteLine("是否包含001: {0}", books.ContainsValue("001"));
Console.WriteLine("是否包含002: {0}", books.ContainsValue("002"));
//此处的索引值是按排序后的顺序
int keyIndex = books.IndexOfKey("zhubajie");
Console.WriteLine("zhubajie的索引值: {0}", keyIndex);
string value = "";
if (books.TryGetValue("tangseng",out value))
{
Console.WriteLine("得到了tangseng的值 : {0}",value);
}
string value2 = "";
if (books.TryGetValue("zhubajie", out value2))
{
Console.WriteLine("得到了zhubajie的值 : {0}", value2);
}
Console.ReadKey();
}
}
}
分析:使用Values和Keys属性访问值和键.如果尝试使用索引器访问一个元素,但所传递的键不存在,就会抛出异常.为了避免一场,可以使用ContainsKey()方法,如果所传递的键存在于集合中,这个方法返回true,也可以调用TryGetValue()方法,该方法尝试获得指定键的值.如果指定键对应的值不存在,该方法就会抛出异常.
C#编程(五十二)----------有序列表的更多相关文章
- Gradle 1.12用户指南翻译——第五十二章. Maven 插件
本文由CSDN博客貌似掉线翻译,其他章节的翻译请参见:http://blog.csdn.net/column/details/gradle-translation.html翻译项目请关注Github上 ...
- Java进阶(五十二)利用LOG4J生成服务日志
Java进阶(五十二)利用LOG4J生成服务日志 前言 由于论文写作需求,需要进行流程挖掘.前提是需要有真实的事件日志数据.真实的事件日志数据可以用来发现.监控和提升业务流程. 为了获得真实的事件日志 ...
- SQL注入之Sqli-labs系列第五十关,第五十一关,第五十二关,第五十三关(ORDER BY堆叠注入)
0x1第五十关 源码中使用的mysqli_multi_query()函数,而之前使用的是mysqli_query(),区别在于mysqli_multi_query()可以执行多个sql语句,而mysq ...
- “全栈2019”Java第五十二章:继承与初始化详解
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...
- 《手把手教你》系列技巧篇(五十二)-java+ selenium自动化测试-处理面包屑(详细教程)
1.简介 面包屑(Breadcrumb),又称面包屑导航(BreadcrumbNavigation)这个概念来自童话故事"汉赛尔和格莱特",当汉赛尔和格莱特穿过森林时,不小心迷路了 ...
- Bristol大学密码学博士生的五十二个知识点
Bristol大学密码学博士生的五十二个知识点 这个系列,是Bristol大学的密码安全工作组为密码学和信息安全相关的博士准备了52个基本知识点. 原地址:http://bristolcrypto.b ...
- 学习ASP.NET Core Razor 编程系列十二——在页面中增加校验
学习ASP.NET Core Razor 编程系列目录 学习ASP.NET Core Razor 编程系列一 学习ASP.NET Core Razor 编程系列二——添加一个实体 学习ASP.NET ...
- 面渣逆袭:Redis连环五十二问,图文详解,这下面试稳了!
大家好,我是老三,面渣逆袭系列继续,这节我们来搞定Redis--不会有人假期玩去了吧?不会吧? 基础 1.说说什么是Redis? Redis是一种基于键值对(key-value)的NoSQL数据库. ...
- abp(net core)+easyui+efcore实现仓储管理系统——出库管理之三(五十二)
abp(net core)+easyui+efcore实现仓储管理系统目录 abp(net core)+easyui+efcore实现仓储管理系统--ABP总体介绍(一) abp(net core)+ ...
随机推荐
- 测试开发之前端——No2.HTML5中的标签
HTML5中的标签. 标签 描述 <!--...--> 定义注释. <!DOCTYPE> 定义文档类型. <a> 定义超链接. <abbr> 定义缩写 ...
- pyqt5-基础
PyQt5是一套来自Digia的Qt5应用框架和Python的粘合剂.支持Python2.x和Python3.x版本. PyQt5以一套Python模块的形式来实现功能.它包含了超过620个类,600 ...
- 20165330《网络对抗技术》Exp0 Kali安装
Kali安装 下载地址 Kali官网 VMware 安装步骤 参考在虚拟机中安装kali linux 安装Kali Linux的镜像和VMware 打开VMware,选择文件-新建虚拟机,出现对话框选 ...
- Java编程的逻辑 (5) - 小数计算为什么会出错?
本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http:/ ...
- js 高阶函数(map/reduce/filter/sort)
1.map - 方法返回一个新数组,数组中的元素为原始数组元素调用函数处理后的值(注:map不会对空数组进行检测,不会改变原始数组) 语法:array.map(function(currentValu ...
- js数组遍历some、foreach、map、filter、every、lastIndexOf、indexOf对比
1. [...].some(ck)函数 对数组中每个元素执行一次ck函数,知道某个元素返回true,则直接返回true.如果都返回false,则返回false 检查整个数组中是否有满足ck函数的元素. ...
- [转]c++优先队列(priority_queue)用法详解
既然是队列那么先要包含头文件#include <queue>, 他和queue不同的就在于我们可以自定义其中数据的优先级, 让优先级高的排在队列前面,优先出队 优先队列具有队列的所有特性, ...
- python 字典相关操作
字典 字典的增删改查 字典的创建方式: # 创建字典类型 info = { 'name':'李白', 'age':'25', 'sex':'男' } msg = { 'user01':'Longzel ...
- 线上zk节点报org.apache.zookeeper.server.NIOServerCnxnFactory.run(NIOServerCnxnFactory.java:187) at java.lang.Thread.run(libgcj.so.10)
线上zk做配置管理,最近突然发现两个节点一直在刷下边 java.nio.channels.CancelledKeyException at gnu.java.nio.SelectionKeyIm ...
- codevs 1086 栈 2003年NOIP全国联赛普及组
题目描述 Description 栈是计算机中经典的数据结构,简单的说,栈就是限制在一端进行插入删除操作的线性表. 栈有两种最重要的操作,即pop(从栈顶弹出一个元素)和push(将一个元素进栈). ...