扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
按照发布计划,Python 3.11.0 将于 2022 年 10 月 24 日发布。
我们提供的服务有:成都网站设计、成都网站建设、微信公众号开发、网站优化、网站认证、博爱ssl等。为上1000+企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的博爱网站制作公司
据测试,3.11 相比于 3.10,将会有 10-60% 的性能提升,这个成果主要归功于“Faster CPython”项目,即“香农计划”。
关于“香农计划”的详情,可查看 Python 之父的主题分享,以及他的一则播客访谈。
3.11 版本为 Python 的提速开了一个激动人心的好头。接下来,3.12 还会有更多动作。
以下文章翻译自“香农计划”的《Python 3.12 Goals》,大家先一睹为快吧!
作者:Mark Shannon
译者:豌豆花下猫@Python猫
英文:https://github.com/faster-cpython/ideas/wiki/Python-3.12-Goals
本文内容可能会改动,以实际版本为准!
本文是 Faster CPython 计划在 3.12 中实现的主要内容的概要。
Python 3.11 提升速度的主要方法是用更快的与上下文相关的操作码(自适应的专门化操作码)替换个别的操作码,下一个大的改进方法是优化多个操作码的运行。
为此,现有的许多高级操作码将被替换成低级操作码,例如,用于检查版本号和引用计数的操作码。这些更简单的操作码更容易进行优化,例如,可以删除冗余的引用计数操作。
这些更底层的操作码还能让我们得到一组适合用于生成机器代码的指令(在 CPython 和第三方 JIT 项目中都适用)。
为了做到这点,解释器循环(interpreter loop)将基于声明性的描述而生成。
这可减少一部分为了保持解释器循环与某些相关函数同步而产生的 bug(mark_stacks、stack_effect 等函数),同时也让我们可以对解释器循环作较大的更改试验。
Python 当前每个进程有一个全局解释器锁(GIL),阻碍了多线程的并行。
PEP-684:https://peps.python.org/pep-0684
PEP-554:https://peps.python.org/pep-0554
PEP-684 提出了一个方案,即保证所有的全局状态都是线程安全的,并移动到每个子解释器的全局解释器锁中使用。
PEP-554 提出了让 Python 创建子解释器的方案(目前只是一个 C API 特性),从而实现真正的多线程并行。
Python猫注:PEP-554 早在 2017 年就提出了,目标是落地在 Python 3.8-3.9 版本,然而事与愿违。早在 2019 年的时候,我还翻译了一篇《Has the Python GIL been slain?》。屠刀已挥出,让它再飞一会~~
我们分析了哪些字节码将从专门化中获益最多,计划在 3.12 完成其余的高收益的改进。
https://github.com/faster-cpython/ideas/issues/74
有许多可以减少 Python 对象结构大小的机会。由于它们被频繁使用,这不仅有利于总体的内存使用,还有利于缓存的一致性。我们计划在 3.12 中实现最有希望的一些想法。
这里有一些向后兼容性与性能之间的权衡问题,可能需要提出一个 PEP 来建立共识。
我们不仅会减小对象的大小,还会使它们的 layout 更加规则。
这不仅能优化内存的分配及释放,还能在 GC 和重新分配期间加快遍历对象的速度。
除了前述项目外,开发团队还将提升 CPython 代码库的整体质量:
注:文中图片为译者所加。
首发于 Python猫 ,如需转载,请联系作者
知乎:Python猫
博客园:豌豆花下猫
掘金:豌豆花下猫
CSDN:Python猫
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流