Erlang OTP 22.0 已发布
2019年5月14日 · 作者:Henrik Nord
OTP 22.0 #
Erlang/OTP 22 是一个新的主要版本,具有新特性和改进,以及一些不兼容之处。
要深入了解 OTP 22 版本的亮点,您可以在此处阅读我们的博客
http://blog.erlang.org/OTP-22-Highlights/
潜在的不兼容性 #
- gen_* 行为: 如果服务器通过
sys:log/2,3
记录最后 N 条消息的功能处于活动状态,则此日志将包含在终止报告中。 - reltool:现在可以在 reltool 版本特定配置格式的 rel 元组中包含一个新元素 Opts:
{rel, Name, Vsn, RelApps, Opts}
。 - 由
erlang:list_to_pid
和类似函数创建的所有外部 pid/端口/引用,现在与来自该节点的任何其他具有相同编号的 pid/端口/引用进行比较时都相等。 - 旧的遗留
erl_interface
库从 OTP 22 开始已被弃用,并将在 OTP 23 中删除。这不适用于ei
库。 - VxWorks 从 OTP 22 开始已被弃用,并将在 OTP 23 中删除。
新特性 #
Erts: #
- 支持 Erlang 分发协议,将大型消息的有效负载拆分为多个片段。
- ETS 选项 write_concurrency 现在也影响并提高了 ordered_set 表的可扩展性。
- 用于计算列表长度的 BIF length/1 过去会一次性计算列表长度而不让步,即使列表非常长。现在,当使用长列表调用时,它会进行让步。
- 引入了一个新的(仍处于实验阶段的)模块
socket
。它被实现为一个 NIF,其理念是使其尽可能“接近”操作系统级别的套接字接口。 - 添加了 NIF 函数
enif_term_type
,它通过返回给定项的类型来帮助避免冗长的enif_is_xyz
序列。这对于序列化项的 NIF(例如 JSON 编码器)特别有帮助,它可以提高性能和可读性。
编译器: #
- 编译器已重写为在内部使用基于静态单赋值 (SSA) 的中间表示。新的中间表示使更多优化成为可能。 * 二进制匹配优化现在比以前适用于更多情况。
- 类型优化现在应用于本地函数调用,并将比以前删除更多冗余的类型测试。
- 所有可以在源文件中给出的编译器选项现在都可以在 erlc 命令行上的选项列表中给出。
- 在 OTP 22 中,HiPE(本机代码编译器)功能不完整。原因在于用于二进制匹配的新 BEAM 指令,HiPE 本机代码编译器不支持这些指令。如果使用
+native
选项调用erlc
,并且使用了任何新的二进制匹配指令,编译器将发出警告并生成不包含本机代码的 BEAM 文件。
标准库: #
- Cover 现在使用 counters 模块而不是 ets 来更新计数器。新的函数 cover:local_only/0 允许在受限但更快的本地模式下运行 Cover。速度的提高将取决于被覆盖编译的代码类型,例如,使用新的 Cover 时,编译器测试套件的运行速度会快两倍以上。
- 通过
socket
模块提供了一个简单的套接字 API。这是一个低级 API,它不替代gen_[tcp|udp|sctp]
。它旨在最终替代 inet 驱动程序。它还提供了一个基本 API,有助于实现除 TCP、UDP 和 SCTP 之外的其他协议。已知的问题有:不支持 Windows 操作系统(目前),存在少量的项泄漏。此功能在 OTP 22 中将被归类为实验性功能。 - SSL:现在使用新的 logger API,包括日志级别和详细的调试日志记录。
- SSL:基本支持 TLS 1.3 服务器,供实验使用。
- crypto:新的
hash_info/1
和cipher_info/1
函数返回包含有关参数中哈希或密码信息的映射。
有关更多详细信息,请参见 https://erlang.ac.cn/download/otp_src_22.0.readme
Windows 的预构建版本可在此处获取: https://erlang.ac.cn/download/otp_win32_22.0.exe https://erlang.ac.cn/download/otp_win64_22.0.exe
可以在此处浏览在线文档: https://erlang.ac.cn/doc/search/
Erlang/OTP 源代码也可以在 GitHub 上的官方 Erlang 仓库中找到
感谢大家的所有贡献!