Python 开发人员非常兴奋,因为这种广受欢迎的编程语言 3.14.0 版本的第一个 alpha 版本已经发布。请记住,这是一个早期的开发人员预览版,也是计划中的七个 alpha 版本中的第一个,这些版本旨在测试新功能和错误修复的当前状态。
与任何 alpha 版本一样,在 beta 阶段开始之前仍可以添加功能,beta 阶段将于 2025 年 5 月 6 日开始。换句话说,alpha 阶段持续六个月以上,因此您有充足的时间来进行测试、了解新功能,以及(更重要的是)报告您可能发现的任何错误。
与任何定点发布版本一样,您不应期望语言或交易(或突破性)功能发生重大变化。这并不意味着您不会在该版本中找到新功能。事实上(根据Python官方博客),新功能仍在计划和编写中,因此无法预测该版本的未来会如何。
目前, Python 3.14.0 alpha 版本新增了两个主要特性,分别是:
- 注释的延迟演进
- 改进错误消息
让我们快速地看一下每一个。
注释的延迟评估
注释的延迟评估意味着函数、类和模块的注释将不再被急切地评估,而是存储在专用的注释函数中,仅在必要时进行评估。
注释函数是评估函数的一个子集,可以调用来检索对象的注释。
添加此更改是为了帮助提高注释的性能并使其更有用。
根据 PEP 649,“新的注释库模块提供了检查延迟注释的工具。注释可以以 VALUE 格式(将注释评估为运行时值,类似于早期 Python 版本中的行为)、FORWARDREF 格式(用特殊标记替换未定义的名称)和 STRING 格式(将注释作为字符串返回)进行评估。”
新的annotationlib模块的调用方式类似如下:
1 | from annotationlib import get_annotations, Format |
对于那些还没有使用过 Python 注释的人来说,它们不仅可以提高代码的可读性,还可以提示变量、函数参数和返回类型的数据类型。Python 中有两种类型的注释:函数注释和变量注释。
函数注释如下所示:
def func(a: | |
pass |
view rawgistfile1.txt hosted with by GitHub
上面的代码片段接受两个参数——a 和 b,然后将返回类型表示为
然后您可以使用 __annotations__ 属性访问注释,如下所示:
def func(num1: int, num2: int=100) -> int : | |
return num1 + num2 | |
print(func.__annotations__) |
view rawgistfile1.txt hosted with by GitHub
改进的错误消息
当前错误消息的改进主要围绕解包赋值。如果解包赋值因变量数量不正确而失败,改进后的错误消息现在会比以前的 Python 版本在更多实例中打印值的数量。
以下是一个例子:
在 Python 解释器(通过输入python3访问)中,输入:
1 | x, y, z = 10, 20, 30, 40 |
在 Python 的早期版本中,打印的错误是:
回溯(最近一次调用最后一次):
文件“
x、y、z = 10、20、30、40
^^^^^^^
ValueError:需要解压的值太多(预期为 3 个)
在 3.14.0 alpha 版本中,该错误消息现在显示为:
回溯(最近一次调用最后一次):
文件“
x、y、z = 10、20、30、40
^^^^^^^
ValueError:要解压的值太多(预期 3 个,实际得到 4 个)
它为您提供了更多信息,这对帮助您调试代码有很大帮助。
下一步
与任何 alpha 版本一样,与开发人员沟通非常重要。如果您认为缺少某个功能,但该功能值得添加,您可以发送电子邮件至hugo@python.org提出您的建议。
下一个 alpha 版本 3.14.0a2 预计将于 2024 年 11 月 19 日发布。
如果您有兴趣测试 Python alpha 3.14,您可以从源代码安装它(在 Linux 上),或者下载其中一个安装程序(macOS、Windows 64 位、Windows 32 位或Windows ARM64)。
请记住,这是一个实验版本,因此不应考虑用于生产用途。