开发工具:
文件大小: 24mb
下载次数: 0
上传时间: 2018-07-21
详细说明: Python 3.7.0 重大功能改进 那么,这次新发布的Python 3.7.0 有哪些重要的改进呢?总的来说, 新的syntax功能: PEP 563,推迟了类型注释(type annotations)的评估 向后不兼容的syntax更改: async 和 await 现在是保留关键词 新的库模块: contextvars:PEP 567 - 上下文变量 dataclasse:PEP 557 - 数据类 importlib.resources 新的内置功能: PEP 553,新的 breakpoint() 函数 Python 数据模型改进: PEP 562,定制访问模块属性 PEP 560,核心支持 typing module 和 generic types dict 对象的插入顺序保存性质被纳入Python官方语言规范 标准库的重大改进: asyncio 模块增加了新功能,提高了可用性和性能 time 模块新增纳秒级函数支持,新函数将纳秒数作为整数值返回 CPython 部署改进: 避免使用 ASCII 作为默认文本编码 PEP 552,deterministic .pycs 新的 runtime 模式 PEP 565,改进了 DeprecationWarning 处理 C API 改进: PEP 539,用于线程本地存储的新C API 文档改进: PEP 545,Python文档翻译 新增日语、法语和韩语文档 Python 3.7.0 新增特性 那么,接下来详细看看这些功能。 PEP 563:推迟对注释语句的评估 Python的类型提示有两个明显的可用性问题: 注释只能使用当前范围内已有的名称,换句话说,它们不支持任何类型的前向引用; 注释源代码对Python程序的启动时间有不利影响。 通过推迟注释评估可以解决这两个问题。编译器不是编译在定义时在注释中执行表达式的代码,而是将注释以字符串形式存储。如果需要,可以使用typing.get_type_hints()在运行时解析注释。在不需要解析的常见情况下,注释的存储成本更低,并且启动时间更快。 PEP 538:C语言环境强制 Python 3系列中的一个持续的挑战是确定一种合理的默认策略,用于处理目前在非Windows平台上使用默认C或POSIX语言环境的“7-bit ASCII”文本编码假设。 PEP 538更新默认解释器命令行界面,自动将该语言环境强制转换为可用的基于UTF-8的语言环境。 自动设置LC_CTYPE意味着核心解释器和C扩展(例如readline)将假设使用UTF-8作为默认文本编码,而不是ASCII。 PEP 540:强制UTF-8 Runtime 模式 新的-X utf8命令行选项和PYTHONUTF8环境变量可用于启用CPython UTF-8模式。 PEP 553:内置breakpoint() Python 3.7新增了内置函数breakpoint(),作为进入Python调试器的简单而一致的方式。 PEP 539:新增用于线程本地存储的C API 虽然Python为线程本地存储支持提供了一个C API; 但现有的线程本地存储(TLS)API使用int来表示所有平台上的TLS密钥,但这既不符合POSIX标准,也不具备任何实际意义上的便携性。 PEP 539通过向CPython提供新的线程本地存储(TSS)API来改变这一点,该API取代了在CPython解释器中使用现有TLS API,同时弃用现有API。TSS API使用新类型Py_tss_t而不是int来表示TSS密钥,这将允许在本地TLS密钥定义的平台上构建CPython。 PEP 562:定制对模块属性的访问 Python 3.7支持在模块上定义__getattr __(),并且只要没有找到模块属性就会调用它。也允许在模块上定义__dir __()。 PEP 564:time 内置函数支持纳秒 为了避免精度损失,PEP 564在timemodule添加了六个新“纳秒”(nanosecond)变量: time.clock_gettime_ns() time.clock_settime_ns() time.monotonic_ns() time.perf_counter_ns() time.process_time_ns() time.time_ns() PEP 565:在__main__中默认显示DeprecationWarning DeprecationWarning的默认处理已更改,以便默认情况下再次显示这些警告,但仅当触发它们的代码直接在__main__模块中运行时才会显示。 PEP 560:新增支持类型模块和泛型 PEP引入了两种特殊方法__class_getitem __()和__mro_entries__,这些方法现在被大多数类和特殊构造用于输入。结果,不同类型的各种操作的速度提高了7倍,可以使用泛型而没有元类冲突,并且修改了类型模块中长期存在的一些bug。 PEP 552:基于哈希的.pyc文件 PEP 552扩展了pyc格式,允许源文件的哈希值用于invalidation,而不是源timestamp。这种.pyc文件称为“hash-based”。默认情况下,Python仍然使用基于时间戳的invalidation,并且不会在运行时生成基于哈希的.pyc文件。可以使用py_compile或compileall生成基于哈希的.pyc文件。 PEP 545:Python文档翻译 PEP 545描述了创建和维护Python文档翻译的过程。添加了三种语言的翻译: •日本:https://docs.python.org/ja/ •法语:https://docs.python.org/fr/ •韩国:https://docs.python.org/ko/ 开发运行时模式:-X dev 新的-X dev命令行选项或newPYTHONDEVMODE环境变量可用于启用CPython的开发模式。在开发模式下,CPython执行额外的运行时检查,这些检查无法在默认情况下启用。 性能提升及文档下载 根据官方文档表示,新升级的各种优化使 Linux 上的 Python 启动时间减少了 10%,而 macOS 上的启动时间更是减少了 30%。 由于字节码更改,方法调用现在可以快 20%。 由于PEP 560工作,typing 导入时间减少了 7 倍,现在许多 typing 操作也更快。 等等优化,还有更多。 ...展开收缩
(系统自动生成,下载前可以参看下载内容)
下载文件列表
相关说明
- 本站资源为会员上传分享交流与学习,如有侵犯您的权益,请联系我们删除.
- 本站是交换下载平台,提供交流渠道,下载内容来自于网络,除下载问题外,其它问题请自行百度。
- 本站已设置防盗链,请勿用迅雷、QQ旋风等多线程下载软件下载资源,下载后用WinRAR最新版进行解压.
- 如果您发现内容无法下载,请稍后再次尝试;或者到消费记录里找到下载记录反馈给我们.
- 下载后发现下载的内容跟说明不相乎,请到消费记录里找到下载记录反馈给我们,经确认后退回积分.
- 如下载前有疑问,可以通过点击"提供者"的名字,查看对方的联系方式,联系对方咨询.