咱们知道linq是一个很古老的东西,你们也知道,自从用了linq,咱们的foreach少了不少,但有一个现实就是咱们在实际应用中使用到的倒是屈指可数mongodb
的几个方法,这个系列我会带领你们看遍linq,好的,废话很少说,先从Aggregate这个貂毛提及。框架
一:应用场景spa
前不久在写一个项目的时候,我须要捞取营销活动,恰好营销活动有两个类型,一种是普通活动,一个是触发式活动,因为存放在两张表中,而且捞取code
以后须要作一些实体的转存,等等计算,因此就有了相似这样的代码。视频
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中,那么这个简单的计算该怎么作到呢???htm
普通的作法: 须要先定义一个List变量,而后一个foreach搞定。blog
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 });
有没有看到,用lamda这种写法多么的连贯,没有第一种写法上的断层,固然不少框架上都有Aggregate这种聚合计算,好比mongodb中一样也有开发
Aggregate,下面咱们用ILSpy看看Aggregate这种魔法化的代码是怎么实现的。
二:探究源码
当你看到源码的时候,是否是有一种亮瞎眼的感受,所谓的Aggregate在内部其实也仅仅是“普通作法”如出一辙的源代码。。。而Aggregate仅仅作的
是一层代码封装,这样也好,提升了咱们开发效率,对吧,以下图:
从图中咱们看到了Aggregate有三种重载方法,本篇恰好用到的是第二种重载,第一种看起来就更简单了,对吧,更况且咱们有ILSpy,欢迎你们自行
探索,本篇就说到这里了,感谢支持~~~
————————————————————————————————————————————————————————————
————————————————————————————————————————————————————————————
友情提示:若是不喜欢看文章,能够移步本系列的 完整版Linq视频教程 【一包烟的钱哦】
————————————————————————————————————————————————————————————
————————————————————————————————————————————————————————————