.NET中扩展方法和Enumerable(System.Linq)

LINQ是我最喜欢的功能之一,程序中到处是data.Where(x=x>5).Select(x)等等的代码,她使代码看起来更好,更容易编写,使用起来也超级方便,foreach使循环更加容易,而不用for int..,linq用起来那么爽,那么linq内部是如何实现的?我们如何自定义linq?我们这里说的linq不是from score in scores  where score > 80 select score;而是System.Linq哦。了解Ling之前先要了解扩展方法,因为linq的实质还是扩展方法。

扩展方法

扩展方法使你能够向现有类型“添加”方法,而无需创建新的派生类型、重新编译或以其他方式修改原始类型。扩展方法是一种特殊的静态方法,但可以像扩展类型上的实例方法一样进行调用。 

例如:

640?wx_fmt=png

微软扩展方法建议

微软MSDN上的建议:通常,建议只在不得已的情况下才实现扩展方法,并谨慎地实现。只要有可能,都应该通过创建从现有类型派生的新类型来达到这一目的。

扩展方法建议

1. 当功能与扩展类型最相关时,可以考虑使用扩展方法。
2. 当对第三方库进行扩充的时候,可以考虑使用扩展方法。
3. 当您不希望将某些依赖项与扩展类型混合使用时,可以使用扩展方法来实现关注点分离。
4. 如果不确定到底使用还是不使用扩展方法,那就不要用。

扩展方法是C#语言的一个很好的补充,她使我们能够编写更好,更容易读的代码,但是也应该小心使用,不恰当的使用扩展方法可能导致可读性降低,使测试困难,容易出错。

System.Linq

System.Linq用起来那么好,她内部是如何实现的,当然是查看源码了。

Where源码

640?wx_fmt=png

这个方法就是一个扩展方法,对数据进行了处理,具体的处理都是在对象中的MoveNext中

640?wx_fmt=png

可以看出就是一个循环处理,如果你觉得还是不清楚,可以看WhereIterator方法

这下明白了,linq就是扩展方法,对数据进行处理,返回所需要的数据,知道了原理之后,可以写自己的linq扩展方法了。
我想写一个带有控制台输出的Where扩展方法

640?wx_fmt=png

实现一个打乱数据的扩展方法,这里的方法用了约束,只能是值类型。

640?wx_fmt=png

到此为止是不是觉得Enumerable中的方法也就是那么回事,没有那么难,我也可以实现。

640?wx_fmt=jpeg


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/315277.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Peaks加强版 黑暗爆炸 - 3551 Kruskal重构树 + 主席树

传送门 文章目录题意:思路:题意: 给你一张图,有nnn个山峰,每个山峰高度为hih_ihi​,有mmm条边,每条边有个难度值wiw_iwi​,现在有qqq个询问,每次询问给定一个山峰vvv&am…

【BJOI2017】树的难题【点分治】【线段树】

传送门 传送门 题意:给一棵树,树上有颜色,每种颜色有权值,定义一条路径的权值为所有颜色相同段的权值之和,求长度在[L,R][L,R][L,R]中的路径的最大权值。 数据范围:暴力过不了 显然是个点分治 对于分治…

Planes, Trains, but not Automobiles-求最小路径覆盖的起点终点

https://vjudge.net/problem/Kattis-planestrainsbutnotautomobiles 题意:给一个有向图,火车可以由任意一个起点开始,每一个点只能经过一次,在坐火车的时候你可以选择坐飞机到另外一个点,求坐飞机的最小次数&#xff…

译 | .NET Core 3.0 对诊断的改进

原文:Sourabh Shirhatti翻译:Edi Wang在 .NET Core 3.0 中,我们将引入一套工具,这些工具利用 .NET 运行时中的新功能,使诊断和解决性能问题变得更加容易。这些运行时功能可帮助您回答一些常见的诊断问题:我…

P4768 [NOI2018] 归程 Kruskal重构树 + 倍增 + 最短路

传送门 文章目录题意:思路:题意: 给你一个联通无向图,每条边有一个长度lll和海拔aaa,当海拔≤\le≤水位线的时候,说明这个道有积水。在起始点有一辆车,车可以走没有积水的路,下车后…

【AT987】高橋君【组合数】【莫队】

传送门 题意:TTT组询问NNN个相同物品选不超过KKK个的方案数,T,N≤1e5T,N \leq 1e5T,N≤1e5 设f(x,y)∑i0yCxif(x,y)\sum_{i0}^{y}C_x^if(x,y)∑i0y​Cxi​即所求 直接求并没有很好的性质 但我们发现:f(x,y)2f(x−1,y)−Cx−1yf(x,y)2f(x-1,y)-C_{x-1…

2021牛客第一场H.Hash Function—FFT求差值的卷

https://ac.nowcoder.com/acm/contest/11166/H 官方题解。 比赛时,我们都是用暴力写的,数据太弱了,今天突然想起来,用fft写了一下。 主要使用fft求差值的卷,乘法我们在多项式的系数上做,加减法 我们在多项…

设计模式之策略者模式

策略者模式简介策略者模式定义一个算法接口,并由其实现类去实现,使得每一个算法都得到封装,并让他们可以相互替换。这是一种行为型模式。策略者模式降低了算法行为和环境角色的耦合度,使得算法可以独立发生变化。策略者模式在现实…

Codeforces Round #622 (Div. 2) D. Happy New Year 状压dp

传送门 文章目录题意:思路:题意: n≤1e5,m≤1e9,k≤8.n\le 1e5,m\le 1e9,k\le 8.n≤1e5,m≤1e9,k≤8. 思路: 注意到题目中保证了每个孩子至多收到kkk个,且k≤8k\le 8k≤8,注意到这是题目保证的&#xff0…

【NOI2015】品酒大会【后缀数组】【并查集】

传送门 传送门 题意:给一个长度为NNN的字符串和一个长度为NNN的序列AAA,对于所有的k∈[0,N−1]k \in [0,N-1]k∈[0,N−1],求选出两个数i,ji,ji,j满足lcp(suffix(i),suffix(j))≥klcp(suffix(i),suffix(j))\geq klcp(suffix(i),suffix(j))≥…

2021牛客第四场-E Tree Xor-线段树区间异或

https://ac.nowcoder.com/acm/contest/11255/E 题目大意:有n个点,每一点有一个区间[l,r]范围的权值可能,有n-1条边,边上的权值为w,ww(u)^w(v),问你满足权值范围和边权值的方案数。 思路:我们把树根的值设为0&#xff…

Codeforces Round #624 (Div. 3) D. Three Integers 数论

传送门 文章目录题意:思路:题意: 给定A,B,CA,B,CA,B,C,找到一个三元组(a,b,c)(a,b,c)(a,b,c),使得aaa是bbb的因子,bbb是ccc的因子,且abs(A−a)abs(B−b)abs(C−c)abs(A-a)abs(B-b)abs(C-c)abs(…

Gym - 100917F Find the Length-用最小路径树求最小环

https://codeforces.com/gym/100917/problem/F 题目大意:就给你一个无向图,求出所有点属于的最小环大小。 思路:我们给每一个点用dji求出最小路径树,然后对于一颗最小路径树,求环。 和树根构成环只有两种情况&#x…

【SPOJ2666】QTree4【链分治】

传送门 题意:给一棵带边权的树,每个点开始时为白色,维护两种操作: 1.改变一个点的颜色(白变黑,黑变白) 2.询问最远的两个白点之间的距离 树分治国集论文 链分治的本质其实就是树链剖分。它们…

【CF1200E】Compress Words【kmp】

传送门 题意:给NNN个由大小写字母、数字组成的字符串,两个字符串S,TS,TS,T合并时,删除TTT最长的是SSS的后缀的前缀,然后接在一起。现将这些字符串依次合并,求最终字符串。 N≤1e5,∑∣Si∣≤1e6N \leq 1e5,\sum|S_i|\leq 1e6N≤1…

Educational Codeforces Round 112 E.Boring Segments-线段树+双指针

https://codeforces.com/contest/1555/problem/E 这场的e好像比较简单。 题目大意,给你n个线段,最大点是m,每一个线段有一个权值w,你能选择线段来覆盖1-m这个区间的,选择的代价为最大权值和最小权值的差。问你最小的…

Codeforces Round #624 (Div. 3) E. Construct the Binary Tree 思维 + 构造

传送门 文章目录题意:思路:题意: 给你n,dn,dn,d,让你构造有nnn个点的二叉树,他们每个节点深度和为ddd。 n,d≤3000n,d\le 3000n,d≤3000. 思路: 先考虑不能构造出来的情况,设sumsumsum为最小…

多项式全家桶学习笔记【持续更新】

本文完成的时间跨度较长,文风变化可能较大…… 最近更新于2020年2月17日 Part 1.主线 乘法 前面讲过FFT 然而FFT常数感人,适用范围还窄,比如不能取模 于是有了NTT 其实就是取模的FFT FFT 需要用到复数ωcos(2πn)sin(2πn)i\omegacos…

2021牛客第五场 I.Interval Queries-回滚莫队

如图&#xff1a;一道很裸的回滚莫队&#xff0c;注意加入的操作和回滚的操作就好了。 #include <cstdio> #include <cstring> #include <string> #include <cmath> #include <iostream> #include <algorithm> #include <queue> #i…

Linux下搭建asp.net运行环境

最近有个项目&#xff0c;是在Windows平台下开发的&#xff0c;需要把 asp.net web应用移植到 CentOS下&#xff0c;甚是头疼&#xff1b;翻阅资料&#xff0c;发现Jexus是个可行的方案&#xff0c;下面是官方对Jexus的定义&#xff1a;什么是JexusJexus是一款Linux平台上的高性…