您好,登錄后才能下訂單哦!
小編給大家分享一下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子句使用數組索引的例子
下面代碼有一個整數數組,我們找出這個數字是否跟他在這個數組的位置一樣
public static void LinqDemo01()
{
int[] numbers = { 5, 4, 1, 3, 9, 8, 6, 7, 2, 0 };
var numsInPlace = numbers.Select((num, index) =>
new { Num = num, InPlace = (num == index) });Console.WriteLine("Number: In-place?");
foreach (var n in numsInPlace)
Console.WriteLine("{0}: {1}", n.Num, n.InPlace);
}
SelectMany 子句使用數組索引的例子
幾個句子組成的數組,我們希望把這幾個句子拆分成單詞,并顯示每個單詞在那個句子中。查詢語句如下:
public static void Demo01()
{
string[] text = { "Albert was here",
"Burke slept late",
"Connor is happy" };
var tt = text.SelectMany((s, index) => from ss in s.Split(' ')
select new { Word = ss, Index = index });foreach (var n in tt)
Console.WriteLine("{0}:{1}", n.Word,n.Index);
}
看完了這篇文章,相信你對“LINQ Where子句怎么用”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。