.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);
        }

原文地址:https://www.cnblogs.com/CloudStrife/p/6227684.html