.net 中select和where的區別


Select(p=>p.IDid)
這里選擇的結果是通過p,訪問迭代器,然后選取的是p.ID
id的結果,選擇到的是bool對象
Where(p=>p.IDid)
這里是過濾,p.ID
id的保留

例子:
Point[] points = new Point[] { new Point(1, 1), new Point(2, 2)};
Console.WriteLine(points.Select(p => p.X == 1).First().GetType());//System.Boolean
Console.WriteLine(points.Where(p => p.X == 1).First().GetType());//System.Drawing.Point

Where 返回的是一個符合匹配的結合(經過過濾的),
Select 返回的也是經過匹配的集合,不過原始集合有多少元素,返回的集合就有多少元素,當然返回的集合的類型是自己定義的

剛自己測試的結果
List str = new List ();
str.Add("1");
str.Add("2");
var strs = str.Select(x => x.ToString() == "1");
foreach (var i in strs)
{
Console.WriteLine(i);
}

        List<string> str2 = new List<string>();
        str2.Add("1");
        str2.Add("2");
        var str2s = str2.Where(x => x.ToString() == "1");
        foreach (var i in str2s)
        {
            Console.WriteLine(i);
        }


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM