使用foreach循环和LINQ的操作有什么区别?

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (70)

我正在解决一个问题,我明白这些代码的工作方式不同,但我不明白为什么第二个代码不正确,有什么区别。

public Person GetOldestMember()
{
    Person oldestPerson = people.OrderByDescending(x => x.Age).FirstOrDefault();

    return oldestPerson;
}

.

public Person GetOldestMember()
{
    Person oldestPerson = new Person(-1); //this is a constructor with parameter age

    foreach (Person person in people)
    {
        if (person.Age > oldestPerson.Age)
        {
            oldestPerson = person;
        }
    }

    return oldestPerson;
}
提问于
用户回答回答于
  • LINQ针对可读性进行了优化; 它易于编写,阅读和理解
  • 但它并不总是那么有效; 它不能利用自定义迭代器之类的东西,并且可能涉及更多对象
  • 简单的操作(OrderBy例如)可能非常昂贵
  • 但是......在大多数情况下,这无关紧要,可读性就是赢家
  • 但是......在某些情况下,这很重要 :)

如果我们假设这是内存中的数据(LINQ对象) -有点像IEnumerable<Person>List<Person>Person[],等:

请注意,排序是一项相对昂贵的操作,使用LINQ时通常也意味着创建数据副本(以便不更改源)。有一些外部扩展方法可以在LINQ概念中更有效地实现这一点,即

Person oldestPerson = people.MaxBy(x => x.Age);

同样,不是高效的循环,但效率比OrderByDescending+ FirstOrDefault...只是注意如何表现为空输入(它可能抛出而不是返回null)。

然而,正如Dzyann在评论中观察到的那样:people这里可能是一个IQueryable<Person>类似于DbSet<Person>EF或LINQ-to-SQL(等)的东西,在这种情况下,一切都在变化:现在我们讨论的是被推送到外部资源的查询,在这种情况下,OrderByDescending+ FirstOrDefault可以成为SQL,如:

SELECT TOP 1 *
FROM People
ORDER BY Age DESC

我们成了英雄。如果我们通过foreach一个IQueryable<Person>,我们会发出:

SELECT *
FROM People

当我们在本地迭代以查看哪个是最旧的时,然后通过网络获取所有内容

热门问答

在serverless中,我能否自己host 一个express(nodejs)的服务?

Tina

腾讯云 · 产品经理 (已认证)

Go Serverless!
推荐
您好,可以这样的。您可以参考如下文档,申请下http function 您可以使用常见的 WEB 框架(如 Nodejs Web 框架:Express、Koa)编写 HTTP 函数。而 WEB 框架内置的一些中间件(如cors)也会极大的方便您的业务编写 文档链接 https:...... 展开详请

使用有过期时间的签名往Cos存储桶中上传文件,若上传还在进行中签名过期,上传是否会终止?

galenye

腾讯 · 工程师 (已认证)

对象存储专业搬砖工
推荐已采纳

如果你是使用的简单上传,它能接收5g以内的文件,那签名过期的文件还在上传的话,是没影响的,因为签名判断是在cos接受到请求时。

如果你是使用的sdk等封装的分片上传,那其实是多个请求去上传文件,如果签名过期了,那上传到某一刻,后面的请求都会返回403

存储桶的默认加速域名 cdn 如何更改业务类型, 即把静态加速改成下载加速?

Jinqn

腾讯 · 高级工程师 (已认证)

腾讯云COS前端开发
推荐

我理解你意思是,浏览器打开的时候要下载,不要直接显示。

通过存储桶的文件 Content-Type 来控制

为何我使用.Net API 生成的临时密钥无法进行文件操作?

推荐
cos有自己的密钥系统,应该是在控制台上,访问管理,API密钥,项目密钥那里,或者去看看cos的文档是如何说明的吧。 你通过ms接口创建cos临时密钥,也许的确会被限制一些,这个需要ms这个产品的人回答下比较好。 生成临时密钥和哪个SDK无关,可以直接在线调用也可以生成,通过AP...... 展开详请

tencentcloud-sdk-php-master github代码上没有vendor文件夹?

推荐
因为和composer冲突,因此导出时没有包含vendor目录。如果需要,可以考虑git clone方式拿到,或者到https://cloud.tencent.com/document/sdk/PHP#.E9.80.9A.E8.BF.87.E6.BA.90.E7.A0.81.E5...... 展开详请

织云安装包在哪里下载?

使用织云,必须要满足1、2步骤1、机器要同步到c.isd.com系统。简单讲,就是在c.isd.com上有这台机器(如果c.isd.com没有,而公司的cmdb【cmdb.oa.com】有,则需要同步到c.isd.com即可,同步需要联系zhiyunhelper同步,而没有的话,...... 展开详请

所属标签

扫码关注云+社区

领取腾讯云代金券