Redian新闻
>
Python 3.12 正式发布:性能提升、no-GIL将在 3.13 提供

Python 3.12 正式发布:性能提升、no-GIL将在 3.13 提供

公众号新闻

推荐关注↓

转自:OSC开源社区(ID:oschina2013)

Python 3.12.0 今日正式发布稳定版。

主要变化

  • 更灵活的 f-string 解析 (PEP 701)

  • 支持 buffer 协议 (PEP 688)

  • 引入新的 debugging/profiling API (PEP 669)

  • 支持具有单独全局解释器锁的独立子解释器 (PEP 684)

  • 优化性能,例如 PEP 709 和对 BOLT 二进制优化器的支持,预计总体性能提高 5%

  • 改进错误信息

  • 支持 Linux perf 分析器在跟踪过程中报告 Python 函数名称

类型注释

  • 为泛型类引入新的类型注释语法 (PEP 695)

  • 为方法引入新的 override 装饰器 (PEP 698)


下面简单介绍值得关注的变化:

更灵活的 f-string 解析 (PEP 701)

新版取消了最初制定 f-strings 时制定的一些限制。经过这些变化,使得 f-strings 更加统一,成为一种可以直接整合到解析器中的正式化语法。这将会为终端用户和库开发者带来较大优势,同时也大大降低用于解析 f-strings 代码的维护成本。

最初设置 f-strings 限制是为了能够在不修改现有词法分析器的情况下将 f-strings 的解析实现到 CPython 中。但目前来看,这些限制反而带来了复杂性。比如:

  1. 在表达式部分中,无法使用引号字符来界定 f-strings

    >>> f'Magic wand: { bag['wand'] }'
    ^
    SyntaxError: invalid syntax
  2. 之前考虑过的一种解决方法会导致在执行的代码中出现转义序列,这在 f-strings 中是被禁止的:

    >>> f'Magic wand { bag[\'wand\'] } string'
    SyntaxError: f-string expression portion cannot include a backslash
  3. f-strings 中无法使用注释语法:

    >>> f'''A complex trick: {
    ... bag['
    bag'] # recursive bags!
    ... }'''

    SyntaxError: f-string expression part cannot include '#'
  4. 许多其它语言表达式字符串插值都支持不扩展转义序列的任意嵌套。比如:

    # Ruby
    "#{ "#{1+2}" }"

    # JavaScript
    `${`${1+2}`}`

    # Swift
    "\("\(1+2)")"

    # C#
    $"{$"{1+2}"}"

Python 团队意识到,从语言用户的角度来看,这些限制没有任何意义,所以他们目前通过赋予 f-strings 字面量一个没有例外的常规语法,并使用专用的解析代码来实现它,从而消除这些限制。

f-strings 的另一个问题是,CPython 中的当前实现依赖于将 f-strings 标记化为 STRING 令牌,并对这些令牌进行后处理。这带来了以下问题:

  1. 它给 CPython 解析器增加了相当大的维护成本。这是因为解析代码需要手动编写,这在历史上导致了大量的不一致性和错误。在 C 中手动编写和维护解析代码一直被认为是容易出错和危险的,因为它需要处理大量的原始词法分析器缓冲区上的手动内存管理。

  2. f-strings 解析代码无法使用新的 PEG 解析器所允许的新错误消息机制,这些错误消息带来的改进已经受到了热烈欢迎,但因为 f-strings 用的是独立解析器,所以无法使用上新改进的错误消息机制。另外,因为 f-strings 有几个语法特性可能会因为在表达式部分内部发生的不同隐式标记化而令人困惑(例如 f"{y:=3}" 并不是一个赋值表达式)

  3. 其它 Python 实现无法知道它们是否正确实现了 f-strings,因为它们并不是官方 Python 语法的一部分。这一点很重要,因为有几个知名的替代实现正在使用 CPython 的 PEG 解析器,如 PyPy。f-strings 使用一个独立的解析器,阻止了这些替代实现利用官方语法,以及从改进的错误消息机制中受益。

期待新 f-strings 能用得更顺心。

给每个子解释器创建 GIL (PEP 684)

PEP-684 由“香农计划”的作者 Eric Snow 提出,主要是给每个子解释器创建 GIL,允许 Python 实现真正的并行处理。

说到并行处理,目前 Python 3.12 尚未引入「no-GIL 构建」。

按照计划,Python 团队会在 Python 3.13 中将 no-GIL 构建添加为实验性构建模式。

相关链接
  • https://www.python.org/downloads/release/python-3120/
  • https://pythoninsider.blogspot.com/2023/10/python-3120-final-now-available.html


- EOF -

推荐阅读  点击标题可跳转

1、程序员未写出赌博程序被拔掉 14 颗牙

2、这个国产自主 IDE 要钉上耻辱柱了吧? 

3、微软宣布 Python 与 Excel “大合体”!!!

4、为什么都是技术合伙人被踢出局?


关注「程序员的那些事」加星标,不错过圈内事

点赞和在看就是最大的支持❤️

微信扫码关注该文公众号作者

戳这里提交新闻线索和高质量文章给我们。
相关阅读
no-GIL Python,启动!老海归给首长会诊nǚ hóng?nǚ gōng将Python程序移植到Mojo,性能提升250倍、速度比C版本快20%留学生零基础入门!MIT内部疯传的Python课,12小时学完!Keras 3.0正式发布!一统TF/PyTorch/Jax三大后端框架,网友:改变游戏规则囤 H100 的都成了大冤种!英伟达发布最新 AI 芯片 H200:性能提升 2 倍,成本下降 50%老黄深夜炸场,世界最强新品震撼发布:性能飙升90%,Llama 2推理速度翻倍 |【经纬低调分享】留学生无门槛入门!MIT内部Python课,12小时学完!PyTorch2.1支持昇腾NPU!华为成为中国首个PyTorch基金会Premier会员刷爆外网!密歇根大学出品12小时速成Python课!零基础也能学囤H100的都成了大冤种!英伟达发布最新AI芯片H200:性能提升2倍,成本下降50%骁龙8 Gen 3处理器发布:CPU性能提升30%、GPU提升25%号称比 Python 快 68000 倍的 Mojo 语言正式发布! Rust 能否与之匹敌?Keras 3.0正式发布:可用于TensorFlow、JAX和PyTorch比Python快68000倍!Mojo正式发布,网友:Python生态系统最重要的升级来了Python重量级证书!UMich出品:亚马逊、谷歌认可,留学生12小时拿下Android 14发布:性能、隐私增强比Python快3.5万倍的Mojo融资7亿,LLVM之父:不会威胁到Python,该恐惧的应该是C++《金缕曲 - 立秋》留学生零基础入门!MIT内部Python课程,12小时学完!推动“工业上楼”、推进综合保税区功能提升、加强帐篷露营地管理……今天的市政府常务会议研究了这些重要事项GitHub热榜登顶:开源版GPT-4代码解释器,可安装任意Python库,本地终端运行比 Python 快 3.5 万倍的 Mojo 融资七亿,LLVM之父:不会威胁到 Python,该恐惧的应该是 C++5131 血壮山河之武汉会战 信罗战役 410倍性能提升-SLS Prometheus 时序存储技术演进Vite 5 正式发布,性能大幅提升苹果A17pro单核比肩英特尔旗舰CPU!和AMD性能相差不到10%,网友:性能快接近M1了刷爆外网!美国密歇根大学出品12小时速成Python课!零基础也能学Python实战 | 使用 Python 和 TensorFlow 构建卷积神经网络(CNN)进行人脸识别详解Python文件: .py、.ipynb、.pyi、.pyc、​.pyd !一篇文章带你了解Python常用自动化测试框架——PytestPython 3.12.0rc1发布红色日记 5.1-10《花信风之立秋》
logo
联系我们隐私协议©2024 redian.news
Redian新闻
Redian.news刊载任何文章,不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。文章信息的合法性及真实性由其作者负责,与Redian.news及其运营公司无关。欢迎投稿,如发现稿件侵权,或作者不愿在本网发表文章,请版权拥有者通知本网处理。