1.ToDictionary,ToLookup

从图中我们看到有四个ToXXX的方法,其中ToArray和ToList,用的是非常非常多

我们有这样的一个实体

    class student
{
public string StuNo { get; set; } //学号
public string Grand { get; set; } //年级
public string Sex { get; set; } //性别
}

年级和学号是一对多的关系,也就是说一个年级可能包含几个学号,每个学号都有自己对应的性别

   class Program
{
static void Main(string[] args)
{ } public static List<student> GetList()
{
return new List<student>()
{
new student(){StuNo="",Grand="一年级",Sex="男"},
new student(){StuNo="",Grand="二年级",Sex="男"},
new student(){StuNo="",Grand="一年级",Sex="女"},
new student(){StuNo="",Grand="一年级",Sex="男"},
new student(){StuNo="",Grand="二年级",Sex="男"},
new student(){StuNo="",Grand="一年级",Sex="女"},
new student(){StuNo="",Grand="二年级",Sex="男"},
new student(){StuNo="",Grand="一年级",Sex="男"},
new student(){StuNo="",Grand="二年级",Sex="女"},
new student(){StuNo="",Grand="一年级",Sex="男"},
new student(){StuNo="",Grand="三年级",Sex="女"},
new student(){StuNo="",Grand="一年级",Sex="人妖"},
new student(){StuNo="",Grand="三年级",Sex="女"}
};
}
}

这种初始化类对象的方法以及返回方式:

 student  s= new student() { Sex = "nan" };

举个例子: 我需要统计各个年级中的学号情况。

很明显,这是一个分组排序的问题,可能你马上就想起了groupby来实现,当然groupby是可以实现的,不过groupby不能算是一种数据结构,不能带有索引,没有字典那样容易输出和操作。

方案一: 采用普通的foreach循环。

一般情况下,可能有一部分人都采用这种原始的方法,将list数据通过foreach循环放到dictionary中,就是代码写的多一些,也算是最灵活的。

static void Main(string[] args)
{
Dictionary<int, student> dic = new Dictionary<int, student>();
List<student> stulist = GetList();
foreach (var item in stulist)
{
if (!dic.ContainsKey(item.Grand))
{
dic.Add(item.Grand, item);
}
else
{
dic[item.Grand] = item;
}
} }

结果

方案二:使用ToDictionary

Dictionary是一种键值方式(值是一个对象)

从图中我们可以看到,发生悲剧的异常了,我们知道dictionary中key是不能重复的,然而ToDictionary中并没有给我们做key的重复值判断,那也就侧面说明ToDictionary在kv中只能是 “一对一”的关系,也就是v中永远只会有一条记录,显然这不是我需要的,在了解ToDictionary原理后,该方案失败。

如果没有重复的

class Program
{
static void Main(string[] args)
{
List<student> stulist = GetList();
var dic = stulist.ToDictionary(m=>m.Grand); } public static List<student> GetList()
{
return new List<student>()
{
new student(){StuNo="",Grand=,Sex="男"},
new student(){StuNo="",Grand=,Sex="男"},
new student(){StuNo="",Grand=,Sex="女"},
};
}
}

结果是

Dictionary的下标只能是键

方案三: 使用ToLookup(键值对,值是一组对象)

ToDictionary的加强版,可以认为是一种新的字典数据结构,它就避免了这种“一对一”的关系,采用“一对多”的实现。

static void Main(string[] args)
{
var stulist = GetList();
var dic = stulist.ToLookup(i=>i.Grand); foreach (var item in dic)
{
Console.WriteLine("年级:" + item.Key); foreach (var item1 in item)
{
Console.WriteLine("\t\t" + item1.StuNo + " " + item1.Sex);
}
}
}

结果

而且ToLookup和字典一样,是带有索引形式,这个groupby就不具备了,当然Tolookup还有一个强大的功能,就是使用Func<TSource, TElement> elementSelector来对现在的v元素进行转换来避免刚才  Console.WriteLine("\t\t" + item1.TicketNo + "  " + item1.Description);语句

static void Main(string[] args)
{
var stulist = GetList();
var dic = stulist.ToLookup(i => i.Grand, j => { return j.StuNo + "\t" + j.Sex; }); foreach (var item in dic)
{
Console.WriteLine("年级:" + item.Key); foreach (var item1 in item)
{
Console.WriteLine("\t\t"+ item1);
}
}
}

输出同样的结果

2.键值对集合

SortedList<TKey, TValue>( )   表示根据键进行排序的键/值对的集合,而键基于的是相关的 IComparer<T> 实现。

SortedDictionary<TKey, TValue>() 表示根据键进行排序的键/值对的集合。

使用KeyValuePair对其进行遍历

            SortedList<int, string> sortedList = new SortedList<int, string>();
foreach (Value val in enumValues)
{
sortedList.Add(Convert.ToInt32(val.EnumValueIndex), val.EnumValueName);
} foreach (KeyValuePair<int, string> e in sortedList)
{
string strName = e.Value;
SelectListItem myli = new SelectListItem
{
Text = strName,
Value = e.Key.ToString(),
Selected = (e.Key == value)
};
cpType.Add(myli);
}

C#经典系列-键值对的更多相关文章

  1. mysql 开发进阶篇系列 10 锁问题 (相同索引键值或同一行或间隙锁的冲突)

    1.使用相同索引键值的冲突 由于mysql 的行锁是针对索引加的锁,不是针对记录加的锁,所以虽然是访问不同行的记录,但如果是使用相同的索引键,是会出现锁冲突的.设计时要注意 例如:city表city_ ...

  2. C# HTTP系列13 以form-data方式上传多个文件以及键值对集合到远程服务器

    系列目录     [已更新最新开发文章,点击查看详细] 类似于以下场景,将表单中的用户信息(包含附件)上传到服务器并保存到数据库中, <form id="form1" run ...

  3. C# HTTP系列12 以form-data方式上传键值对集合到远程服务器

    系列目录     [已更新最新开发文章,点击查看详细] 使用multipart/form-data方式提交数据与普通的post方式有一定区别.multipart/form-data的请求头必须包含一个 ...

  4. Android系统编程入门系列之应用内键值对数据的简单保存

    在应用程序间及与用户的通信交互过程中,会产生并传递一系列数据.针对这些数据,有部分是只在应用程序中使用的缓存数据,还有一部分是在不同位置多次或长时间使用的持久化数据. 对于缓存数据来说,通常以代码中定 ...

  5. iOS监听模式系列之键值编码KVC、键值监听KVO的简单介绍和应用

    键值编码KVC 我们知道在C#中可以通过反射读写一个对象的属性,有时候这种方式特别方便,因为你可以利用字符串的方式去动态控制一个对象.其实由于ObjC的语言特性,你根部不必进行任何操作就可以进行属性的 ...

  6. Hadoop概念学习系列之谈hadoop/spark里为什么都有,键值对呢?(四十)

    很少有人会这样来自问自己?只知道,以键值对的形式处理数据并输出结果,而没有解释为什么要以键值对的形式进行. 包括hadoop的mapreduce里的键值对,spark里的rdd里的map等. 这是为什 ...

  7. OAF_OAF控件系列10 - Key Flexfield键值弹性域的实现(案例)

    2014-06-17 Created By BaoXinjian

  8. redis 系列 在 vs上 set,get 键值

    1.启动两个 cmd,一个用于打开服务,一个用于运行客户端. 详细步骤可见上一篇文章 2.下载nuget的 ServiceStack.Redis;  ,并在using中引用 ,详细步骤可见上一篇文章 ...

  9. PowerDotNet平台化软件架构设计与实现系列(05):ETCD分布式键值存储平台

    ETCD目前在PowerDotNet已经被用于注册中心和配置管理(常见的配置中心在PowerDotNet中仅仅是一个小小的模块而已)中,作为基础设施的重要组成部分,ETCD的重要性不言而喻. 本文简单 ...

随机推荐

  1. Python自动化之5种session类型

    Django中默认支持Session,其内部提供了5种类型的Session供开发者使用: 数据库(默认) 缓存 文件 缓存+数据库 加密cookie 1.数据库Session Django默认支持Se ...

  2. Web开发 < base target>

    target就是点击链接后跳转到的目标页.通俗点说,就是你当前页面上的链接<a>,也包括<img>.<link>.<form>,除非你指定了target ...

  3. IE8-下背景色半透明滤镜在jquery动画中失效问题记录

    前两天,UIer跟我说,把这些按钮都悬浮在这个图片上!我心中千万头草泥马奔过,图片各种各样.花花绿绿.五颜六色的,这几个按钮也没有多大的光环围绕,用户一眼看上去恐怕会以为这是图片的一部分吧!~~~我假 ...

  4. css.day02.eg

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  5. 表达式:使用API创建表达式树(1)

    表达式树可使用Expressions类的静态工厂方法来创建.这种用API的方式创建给予我们在编程极大的灵活性,MSDN上关于表达式的例子也不少,但在使用过程中还是会遇到许多麻烦,对有的表达式类,介绍得 ...

  6. sql 列轉行、行轉列

    PIVOT用于将列值旋转为列名(即行转列),在SQL Server 2000可以用聚合函数配合CASE语句实现 PIVOT的一般语法是:PIVOT(聚合函数(列) FOR 列 in (…) )AS P ...

  7. Oracle存储过程及函数

    1.在Oracle中,存储过程包括三部分组成:定义部分.执行部分.和异常处理部分(即例外) eg1:输入员工编号,查询员工的姓名和薪资 create or repalce  procedure myp ...

  8. firebug js版

    1.有些时候如 ie6 7 8 你觉得F12 不好用的话  你可以直接 把这两个js 引用到html 里面 <script src="https://getfirebug.com/fi ...

  9. Tweet button with a callback – How to?

    原文: http://jaspreetchahal.org/tweet-button-with-a-callback-how-to/ 两种方式:1. 原生的button <a href=&quo ...

  10. thinkphp框架之模型(数据库查询)

    1. 模型定义 文件名称必须是 表名+Model.class.php 例如:UserModel.class.php namespace Home\Model; //该模型类的命名空间 use Thin ...