.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