首页 > 其他分享 >Linq专题之提高编码效率—— 第一篇 Aggregate方法

Linq专题之提高编码效率—— 第一篇 Aggregate方法

时间:2023-04-18 12:39:48浏览次数:51  
标签:第一篇 Marketing MarketingName Linq dic MarketingID Aggregate new


的几个方法,这个系列我会带领大家看遍linq,好的,废话不多说,先从Aggregate这个貂毛说起。

 

一:应用场景

  前不久在写一个项目的时候,我需要捞取营销活动,刚好营销活动有两个类型,一种是普通活动,一个是触发式活动,由于存放在两张表中,并且捞取

之后需要做一些实体的转存,等等计算,所以就有了类似这样的代码。


1 namespace ConsoleApplication1
 2 {
 3     class Program
 4     {
 5         static void Main(string[] args)
 6         {
 7             Dictionary<int, List<Marketing>> dic = new Dictionary<int, List<Marketing>>();
 8 
 9             //普通活动
10             if (!dic.ContainsKey(1))
11                 dic[1] = new List<Marketing>();
12             dic[1].Add(new Marketing() { MarketingID = 1, MarketingName = "普通活动1" });
13             dic[1].Add(new Marketing() { MarketingID = 1, MarketingName = "普通活动2" });
14 
15             //事件活动
16             if (!dic.ContainsKey(2))
17                 dic[2] = new List<Marketing>();
18             dic[2].Add(new Marketing() { MarketingID = 3, MarketingName = "事件活动1" });
19             dic[2].Add(new Marketing() { MarketingID = 4, MarketingName = "事件活动2" });
20         }
21     }
22 
23     class Marketing
24     {
25         public int MarketingID { get; set; }
26 
27         public string MarketingName { get; set; }
28     }
29 }


然后我经过一系列运算之后,又需要把字典中的key=1和key=2的数据扁平到一个list中,那么这个简单的计算该怎么做到呢???

 

普通的做法:


1             List<Marketing> marketingList = new List<Marketing>();
2             foreach (var key in dic.Keys)
3             {
4                 marketingList.AddRange(dic[key]);
5             }


 如果你不会用Aggregate的话,你会觉得这个方法已经非常极致了。。。而事实呢???我们应该还有更牛逼的做法!!!

 

牛逼的做法:


1             var marketingList = dic.Keys.Aggregate(Enumerable.Empty<Marketing>(), (total, next) =>
2               {
3                   return total.Union(dic[next]);
4               });


Linq专题之提高编码效率—— 第一篇 Aggregate方法_Linq

有没有看到,用lamda这种写法多么的连贯,没有第一种写法上的断层,当然很多框架上都有Aggregate这种聚合计算,比如mongodb中同样也有

Aggregate,下面我们用ILSpy看看Aggregate这种魔法化的代码是怎么实现的。

 

二:探究源码

   当你看到源码的时候,是不是有一种亮瞎眼的感觉,所谓的Aggregate在内部其实也仅仅是“普通做法”一模一样的源代码。。。而Aggregate仅仅做的

是一层代码封装,这样也好,提高了我们开发效率,对吧,如下图:

Linq专题之提高编码效率—— 第一篇 Aggregate方法_Marketing_02

 

从图中我们看到了Aggregate有三种重载方法,本篇刚好用到的是第二种重载,第一种看起来就更简单了,对吧,更何况我们有ILSpy,欢迎大家自行

探索,本篇就说到这里了,感谢支持~~~

 

 

标签:第一篇,Marketing,MarketingName,Linq,dic,MarketingID,Aggregate,new
From: https://blog.51cto.com/u_15353947/6202802

相关文章

  • 15天玩转redis —— 第一篇 开始入手
     双十一终于还是过去了,我负责的mongodb由于做了副本集,最终还是挺过去了,同事负责的redis,还是遗憾的在早上8点左右宕机了,然后大家就是马不停蹄的赶往公司解决问题,因为我对redis也不是很了解,工作上使用redis的时候也是应付的找找资料,所以没有从系统层......
  • Linq专题之提高编码效率—— 第二篇 神一样的匿名类型
    说起匿名类型,我们都知道这玩意都是为linq而生,而且匿名类型给我们带来的便利性大家在实战中应该都体会到了,特别适合于一次性使用,临时使用这些场景,虽然说是匿名类型,也就是说是有类型的,只是匿名了而已,对吧,这篇我们就来探索下匿名类型到底和linq有多大关系呢???......
  • docker部署gitlab CI/CD (一)第一篇:部署gitlab及汉化
    网上很多类似教程,但多少有点夹带私货,竟然拉取的第三方镜像,不敢乱用,于是结合其他人的博客和官方文档,结合部分其他作者的笔误踩的坑,知其然也要知其所以然,于2023年4月17日写下这篇。官方文档:https://docs.gitlab.com/ee/install/docker.html主要参考博客:https://www.......
  • 第一篇——为什么要学编写通达信指标公式(从零起步编写通达信指标公式系列)
    技术指标简单来说就是用运用一些计算公式对行情数据进行处理,得到计算结果,根据这些结果,可以成绘制图形,用来辅助行情判断。比如常见的MA均线指标、MACD指标、KDJ指标等。技术指标也可以改编成选股指标,从市场中的几千只股票中粗选出符合自己要求的股票,然后再进行人工分析,减少工作量......
  • 引导与趣味——儿童教育和知识灌输第一篇
    今天先写一个短篇,关于儿童教育和知识灌输的内容,如何让孩子感到学习有趣,在必要的时候也要进行适当的强制,毕竟学习不是本能的趋势,否则人人都应该成为一方专家(不是砖家)。打屁股的故事今天我们先从2020年11月14日我家里发生的一个故事讲起。九迁在吃东西的时候突然提到说可惜他的屁股不......
  • 实话谈扶贫第一篇——教育扶贫
    最近这两年,扶贫是一个非常大的话题,也非常重要,其实不仅仅是对于中国,全世界都是如此,如何扶贫,怎么扶贫,争议都很多,甚至有人因为扶贫问题出了书,随后获得了诺贝尔奖。经过一个月的撰写修订和思考,本文将分为三个篇章发布,分别是:教育扶贫、医疗扶贫和产业扶贫。教育扶贫帮助贫困地区的同胞解......
  • ES6 NO.1( var、let 和 const 命令 )| 前端小白的的第一篇博客~
    varvar声明的变量存在变量提升即在声明该变量之前就可以使用,值为undefined,其作用域为全局;let和constlet用法类似于var,但是所声明的变量,只在let命令所在的代码块内有效;const只能用来声明常量,一旦赋值,不能修改,故使用const不能只声明不赋值;区别var和let......
  • 阅读笔记四月第一篇
    一个理想的设计的特征这一章我主要了解了一个理想设计的特征,书中是这样说的: 一个理想的设计的特征是怎样的呢? 他们有一些共同的特征,这里罗列里一些,虽然都是一个一个的点,但你可以以此针对你做出的设计一一对照一下。1)最小的复杂度:你的设计得很容易看懂,很清晰明了,而不是自作......
  • C#版本LINQ增强开源库
    LINQ对应的中文名称是:语言集成查询,是对一系列直接将查询功能集成到C#语言技术的统称,我们最常用的场景是,用于数据库的查询功能。在.Net中,本身对Objects也支持LINQ的扩展,但是对于一些特定的功能,就需要我们自己去扩展。所以,今天给大家推荐一个LINQ扩展库,主要是针对“LINQtoObject......
  • 在LINQPad中使用FreeSql查询数据库
    如何在LINQPad中使用FreeSqlLINQPad是一款强大的C#交互式编程环境,它可以让你轻松地编写和测试C#代码片段。除了作为一个交互式编程环境,LINQPad还可以用来连接各种数据源,包括SQL数据库、NoSQL数据库、Web服务等等。此外,LINQPad还支持使用NuGet包管理器来安装和管理第三方库。有时......