返回介绍

迭代和优化

发布于 2024-01-29 22:24:17 字数 914 浏览 0 评论 0 收藏 0

如果for循环看起来就像之前介绍的列表解析表达式一样,那也没错。它们都是真正的通用迭代工具。事实上,它们都能够工作于遵守迭代协议(这是Python中无处不在的一个概念,表示在内存中物理存储的序列,或一个在迭代操作情况下每次产生一个元素的对象)的任意对象。如果一个对象在响应next之前先用一个对象对iter内置函数做出响应,那么它属于后一种情况。我们在前面所见到的生成器解析表达式就是这样的一个对象。

本书稍后将会详细介绍迭代协议。现在记住,从左到右地扫描一个对象的每个Python工具都使用迭代协议。这就是为什么前面一节所介绍的sorted调用直接工作于字典之上,我们不必调用keys方法来得到一个序列,因为字典是可迭代的对象,可以用一个next返回后续的键。

这也意味着像下面这样的任何列表解析表达式都可以计算一列数字的平方:

能够编写成一个等效的for循环,通过在运行时手动增加列表来创建最终的列表:

尽管这样,列表解析和相关的函数编程工具,如map和filter,通常运行得比for循环快(也许快了两倍):这是对有大数据集合的程序有重大影响的特性之一。在Python中性能测试是一个很难应付的任务,因为它在反复地优化,也许版本和版本之间差别很大。

Python中的一个主要的原则就是,首先为了简单和可读性去编写代码,在程序可以工作,并证明了确实有必要考虑性能后,再考虑该问题。更多的情况是代码本身就已经足够快了。如果确实需要提高代码的性能,那么Python提供了帮助你实现的工具,包括time以及timeit模块和profile模块。你将会在本书稍后部分以及Python的手册中学到更多内容。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文