细说Linq之Aggregate

前言

Linq中有关常见的方法我们已经玩的得心应手,而对于那些少用的却是置若罔闻(夸张了点),但只有在实际应用中绞尽脑汁想出的方法还不如内置的Linq方法来的实际和简洁,不喜勿喷,怪我见识短。

通过Ruby引入话题

之前在Ruby中演示了一段代码来讲述Ruby的神奇,下面我们再来看一下:

sum = 0
i = 0
(1..101).each do|elem|
  sum+=i
  i+=1
end
puts sum

是的就是这段代码,求1到100的和,代码的优美和简洁让我惊叹。

通过C#继续引入话题 

如果你是有两年工作经验以上的人,当在面试时,面试官给你出这样一道题:请编码求出1到100的和,用两种或两种以上或者更简洁的方法来实现。你是否很快就写出来了呢?我们来看看。

the first way

            var sum = 0;
            for (int i = 1; i <= 100; i++)
            {
                sum += i;
            }
            Console.WriteLine(sum);        

一气呵成,这可难不倒有过两年工作经验以上的人,牛逼哄哄的。马不停蹄,走你,进行第二种方式。

the second way

复制代码
        static int Sum()
        {
            var sum = 0;
            var i = 1;
            do
            {

                sum += i;
                i++;
            } while (i <= 100);
            return sum;
        }
复制代码

哦,果然速度,既然都有do while了 ,不是说要两种或两种以上的方式吗,继续来一个。

the third way

复制代码
        static int Sum()
        {
            var sum = 0;
            var i = 1;
            while (i <= 100)
            {

                sum += i;
                i++;
            } 
            return sum;
        }
复制代码

好,到此就算完事了,轻轻松松就ok了,面试官一看,继续问你,除了这些还有其他方式吗,你果断说没有,此时面试官说基本上算满意,不好意思,只能给你个及格,你是不是正在纳闷呢?什么情况,你说的两种或两种以上的方法我都已经实现了而且是最简洁的方式啊,而且结果都是对的,会不会觉得面试官是在跟你抬杠呢?。 

如果是在此之前我也会这样写,我一直坚信这是在C#中实现1到100的和的唯一方式(当然也可以用do while和while之类的,其实都差不多),此时我们需要想想,面试官的意图是什么,就是为了考你这个,好歹也是工作两年以上的人了,这简直是看不起人嘛,是的确实有点看不起人,作为工作经验比较足的人,你考我这个,没错,正是因为工作经验足才考你这个,但是你却没能体现你的能力。好了,点到为止,我们开始步入正题,此时你有没有发现代码还是有点繁琐,C#简洁的语法跑到哪里去了,让我开始对我最钟情的C#有点不坚定了。

Aggregate

这个就是我们久久未引入的话题,利用它我们完全可以写出如Ruby一样优美的代码,我们来看看是如何求出1到100的和的:

            var list = Enumerable.Range(1, 100);
            var result = list.Aggregate((a, b) => (a + b));
            Console.WriteLine(string.Format("1到100的和为{0}", result));

就是这么easy,让我眼前一亮,对C#又充满了信心,正如上述而言,作为有工作经验的人,可能这个方法确实没有怎么用过,用的大多数是常见的Linq,当然了那么多Linq哪能全部都会用啊,但是,但是至少得了解这个Linq是做什么的吧(别往心里去,说的没见识的我)。

用法

该Linq字面意思为聚合,例如可用来对集合进行筛选以及上述的求和等等,它有三个重载,它是对列表上的每个元素执行操作,也就是说对第一个和第二个上的元素执行操作,将执行的结果继续携带进行操作。其中有一个重载是种子重载。

种子重载(Seed Overload)

我们求1到5的阶乘。

            var nums = Enumerable.Range(2, 4);
            var sum = nums.Aggregate(1, (a, b) => a * b);
            Console.WriteLine(sum);

所谓种子,也就是先从种子开始作为第一个元素执行操作,整个过程为((((1*2)*3)*4)*5)。

结语 

本来没怎么接触过Aggregate,在项目中看到别人写到这么一段代码才让我下意识的知道对这个Linq完全没接触过,于是就有这一部分内容。在项目中有这样一个场景:打开对话框上传文件,可以对该文件进行命名,但是我们知道文件名是无法以某些特殊字符命名的如<或者|等等,当文件名为这些时,上传到后台我们会进行替换处理用“-”来进行替换。我们看看代码,例如:

            var invalidFileName = Path.GetInvalidFileNameChars();
            var replaceResult = invalidFileName.Aggregate("study<Aggregate>first", (accmulate, result) => (accmulate.Replace(result, '-')));
            Console.WriteLine(replaceResult);

结果如下:

Aggregate学习完毕,Sleep now!


为了方便大家在移动端也能看到我分享的博文,现已注册个人公众号,扫描上方左边二维码即可,欢迎大家关注,有时间会及时分享相关技术博文。

感谢花时间阅读此篇文章,如果您觉得这篇文章你学到了东西也是为了犒劳下博主的码字不易不妨打赏一下吧,让楼主能喝上一杯咖啡,在此谢过了!
如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!
本文版权归作者和博客园共有,来源网址:http://www.cnblogs.com/CreateMyself)/欢迎各位转载,但是未经作者本人同意,转载文章之后必须在文章页面明显位置给出作者和原文连接,否则保留追究法律责任的权利。
posted @   Jeffcky  阅读(14416)  评论(6编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示