资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

LINQWhere子句怎么用

小编给大家分享一下LINQ Where子句怎么用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

在安仁等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供成都网站制作、网站设计 网站设计制作按需规划网站,公司网站建设,企业网站建设,成都品牌网站建设,成都营销网站建设,成都外贸网站建设公司,安仁网站建设费用合理。

LINQ Where子句其实是用扩展方法来实现的

微软替我们实现的 LINQ Where子句对应的扩展函数实际是如下的定义:

namespace System.Linq  {  public delegate TResult Func(TArg0 arg0, TArg1 arg1);  public static class Enumerable  {  public static IEnumerable Where(this IEnumerable source, Func predicate);  public static IEnumerable Where(this IEnumerable source, Func predicate);  }  }

我们这个扩展函数参数:Func predicate 的定义看上面代码的绿色delegate 代码。

LINQ Where子句参数书写的是Lambda 表达式

(dd, aa) => dd.Length < aa 就相当于 C# 2.0 的匿名函数。

LINQ中所有关键字比如 Select,SelectMany, Count, All 等等其实都是用扩展方法来实现的。上面的用法同样也适用于这些关键字子句。这个LINQ Where子句中Lambda 表达式第二个参数是数组索引,我们可以在Lambda 表达式内部使用数组索引。来做一些复杂的判断。具有数组索引的LINQ关键字除了Where还以下几个Select,SelectMany, Count, All。

Select子句使用数组索引的例子

下面代码有一个整数数组,我们找出这个数字是否跟他在这个数组的位置一样

  1. public static void LinqDemo01()  

  2. {  

  3. int[] numbers = { 5, 4, 1, 3, 9, 8, 6, 7, 2, 0 };  

  4. var numsInPlace = numbers.Select((num, index) => 
    new { Num = num, InPlace = (num == index) });  

  5. Console.WriteLine("Number: In-place?");  

  6. foreach (var n in numsInPlace)  

  7. Console.WriteLine("{0}: {1}", n.Num, n.InPlace);  

SelectMany 子句使用数组索引的例子

几个句子组成的数组,我们希望把这几个句子拆分成单词,并显示每个单词在那个句子中。查询语句如下:

  1. public static void Demo01()  

  2. {  

  3. string[] text = { "Albert was here",  

  4. "Burke slept late",  

  5. "Connor is happy" };  

  6. var tt = text.SelectMany((s, index) => from ss in s.Split(' ') 
    select new { Word = ss, Index = index });  

  7. foreach (var n in tt)  

  8. Console.WriteLine("{0}:{1}", n.Word,n.Index);  

  9. }  

看完了这篇文章,相信你对“LINQ Where子句怎么用”有了一定的了解,如果想了解更多相关知识,欢迎关注创新互联行业资讯频道,感谢各位的阅读!


文章题目:LINQWhere子句怎么用
转载来源:http://cdkjz.cn/article/gjdcdd.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

业务热线:400-028-6601 / 大客户专线   成都:13518219792   座机:028-86922220