Python 3.12的目标:更高效的性能!
时间:2023-04-22 15:34
按照发布计划,Python 3.11.0 将于 2022 年 10 月 24 日发布。 据测试,3.11 相比于 3.10,将会有 10-60% 的性能提升,这个成果主要归功于“Faster CPython”项目,即“香农计划”。 3.11 版本为 Python 的提速开了一个激动人心的好头。接下来,3.12 还会有更多动作。 以下文章翻译自“香农计划”的《Python 3.12 Goals》,大家先一睹为快吧! 本文内容可能会改动,以实际版本为准! 本文是 Faster CPython 计划在 3.12 中实现的主要内容的概要。 Python 3.11 提升速度的主要方法是用更快的与上下文相关的操作码(自适应的专门化操作码)替换个别的操作码,下一个大的改进方法是优化多个操作码的运行。 为此,现有的许多高级操作码将被替换成低级操作码,例如,用于检查版本号和引用计数的操作码。这些更简单的操作码更容易进行优化,例如,可以删除冗余的引用计数操作。 这些更底层的操作码还能让我们得到一组适合用于生成机器代码的指令(在 CPython 和第三方 JIT 项目中都适用)。 为了做到这点,解释器循环(interpreter loop)将基于声明性的描述而生成。 这可减少一部分为了保持解释器循环与某些相关函数同步而产生的 bug(mark_stacks、stack_effect 等函数),同时也让我们可以对解释器循环作较大的更改试验。 Python 当前每个进程有一个全局解释器锁(GIL),阻碍了多线程的并行。 PEP-684 提出了一个方案,即保证所有的全局状态都是线程安全的,并移动到每个子解释器的全局解释器锁中使用。 PEP-554 提出了让 Python 创建子解释器的方案(目前只是一个 C API 特性),从而实现真正的多线程并行。 我们分析了哪些字节码将从专门化中获益最多,计划在 3.12 完成其余的高收益的改进。 https://www.php.cn/link/7392ea4ca76ad2fb4c9c3b6a5c6e31e3 有许多可以减少 Python 对象结构大小的机会。由于它们被频繁使用,这不仅有利于总体的内存使用,还有利于缓存的一致性。我们计划在 3.12 中实现最有希望的一些想法。 这里有一些向后兼容性与性能之间的权衡问题,可能需要提出一个 PEP 来建立共识。 我们不仅会减小对象的大小,还会使它们的 layout 更加规则。 这不仅能优化内存的分配及释放,还能在 GC 和重新分配期间加快遍历对象的速度。 除了前述项目外,开发团队还将提升 CPython 代码库的整体质量: 以上就是Python 3.12的目标:更高效的性能!的详细内容,更多请关注Gxl网其它相关文章!跟踪优化器
多线程并行
更多专门化
较小的对象结构
减少内存管理的开销
API 稳定性