将 Perl 5 代码迁移到 Perl 6

了解将 Perl 5 程序移植到 Perl 6 时可能遇到的问题。
209 位读者喜欢这篇文章。
Perl 6 logo butterfly

Larry Wall。GNU 通用公共许可证或 Artistic License 2

无论您是正在采取第一步将 Perl 5 代码转换为 Perl 6 并遇到一些问题的程序员,还是仅仅对尝试将 Perl 5 程序移植到 Perl 6 可能会发生什么感兴趣,本文都应该解答您的疑问。

Perl 6 文档 已经包含了您处理将 Perl 5 代码迁移到 Perl 6 时将遇到的问题所需的大部分(如果不是全部)文档。但是,正如文档所述,重点在于事实上的差异。我将尝试更深入地探讨具体问题,并根据我将大量 Perl 5 代码移植到 Perl 6 的经验,提供更多实践信息。

Perl 6 怎么样?

非常好,谢谢!自 2015 年 12 月首次正式发布以来,Rakudo Perl 6 的性能提升了一个数量级,并且修复了许多错误(总共超过 14,000 次提交)。到目前为止,已经出版了七本关于 Perl 6 的书籍。Brian D. Foy 的 Learning Perl 6 即将由 O'Reilly 出版,该书根据开创性的 Learning Perl(又名“Llama Book”)改编而成,许多人都熟知并喜爱这本书。

用户发行版 Rakudo Star 每三个月发布一次,并且在 Perl 6 生态系统 中提供了 1,100 多个模块。Rakudo 编译器版本每月发布一次,通常包含 30 多人的贡献。Perl 6 模块上传到 Perl 编程作者上传服务器 (PAUSE),并通过综合 Perl 档案网络 (CPAN) 在全球范围内分发。

在线 Perl 6 简介 文档已被翻译成 12 种语言,向超过 30 亿人以他们的母语教授 Perl 6。最新版本的 Perl 6 Weekly 自 2014 年 2 月以来每周都会报道有关 Perl 6 的所有信息。

Cro,一个微服务框架,从头开始使用 Perl 6 的所有功能,提供 HTTP 1.1 持久连接、带有请求多路复用的 HTTP 2.0 以及带有可选证书颁发机构的 HTTPS。并且 Perl 6 IDE 现在处于(付费)beta 测试阶段(可以将其视为带有即时交付成果的 Kickstarter)。

在 Perl 6 中使用 Perl 5 功能

Perl 5 代码可以使用 Inline::Perl5 模块与 Perl 6 无缝集成,从而使 CPAN所有内容都可用于任何 Perl 6 程序。这可以被认为是作弊,因为它将嵌入 Perl 5 解释器,因此仍然依赖于 perl (5) 运行时。但是,如果您需要访问尚未移植的模块,只需在 use 语句中添加 :from<Perl5>,例如 use DBI:from<Perl5>;,就可以轻松地运行 Perl 6 代码。

2018 年 1 月,我提出了一个 CPAN 蝴蝶计划,旨在尽可能接近原始 API 将 Perl 5 功能转换为 Perl 6。我将此作为目标,因为 Perl 5(作为一种编程语言)不仅仅是语法。问问任何人 Perl 的独特卖点是什么,他们很可能会告诉您是 CPAN。因此,我认为现在是从这种 Perl 世界观

Dromecentric view

转变为更现代的观点的时候了

Cpannican view

换句话说:将 CPAN 作为 Perl 最重要的元素放在中心位置。

转换语义

要在 Perl 6 中以原生方式运行 Perl 5 代码,您还需要大量的 Perl 5 语义。在 Perl 6 中提供(可选的)Perl 5 语义支持降低了 Perl 5 程序员在尝试使用 Perl 6 编程时感知的概念门槛。更容易感到宾至如归!

自 CPAN 蝴蝶计划发布以来,Perl 6 现在支持 100 多个内置 Perl 5 函数,API 相同。许多函数已经存在于 Perl 6 中,但语义略有不同,例如,Perl 5 中的 shift 如果未指定参数,则神奇地从 @_(或 @ARGV)中移位;在 Perl 6 中,参数是强制性的。

超过 50 个 Perl 5 CPAN 发行版也已移植到 Perl 6,同时遵守了原始 Perl 5 API。其中包括核心模块,例如 Scalar::UtilList::Util,以及非核心模块,例如 Text::CSVMemoize。在 CPAN 之河 上游的发行版旨在尽可能地对生态系统产生影响。

总结

Rakudo Perl 6 已经成熟到可以使用 Perl 6 来创建新的交互式项目。能够使用可靠且经过验证的 Perl 5 语言组件有助于降低开发人员使用 Perl 6 的门槛,并且它朝着 Perl 5 和 Perl 6 的总和大于其各部分之和的情况发展。

Elizabeth Mattijsen
Elizabeth Mattijsen 自 1978 年以来一直以编程为生,使用过各种(现在大多已废弃的)编程语言,之后才开始使用 Perl 4 进行编程。1994 年,她创立了荷兰第一家商业网站开发公司,使用 Perl 5 作为主要编程语言。从 2003 年起,她参与了一家在线酒店预订服务的快速增长。

6 条评论

?

经验丰富的 Perl 程序员的良好总结。我想开始使用 Perl 6!

哇,很棒的文章,Elizabeth!
Perl6 听起来很吸引人,有了这些新的发展。现在,我正在考虑重新开始编程,使用一种新的语言,Julia、Nim、Crystal、Object Pascal/Lazarus(我喜欢 Pascal 语法!)、Swift、Rust 和 Kotlin 真的让我很感兴趣。实际上,我刚刚在 Udemy 上注册了“从零开始学习和掌握 Julia 编程语言”——还没有开始!

现在,Perl 6 出现了,我想知道我是否应该先追求它。但另一方面,我真的想要一种静态编译语言,它可以输出一个快速的可执行文件,以“接近”C 速度运行。Perl 不是解释型的吗?

您能否向我们介绍一下 Perl6 的性能,以及我们对未来应该有什么期望——随着代码库的成熟——在性能(编译器等)方面相对于我上面提到的语言而言?

干杯!

-Dark Matter
****
计算机编程的第一和第二定律
1) 永远不要相信未经彻底调试的程序。
2) 没有程序是永远彻底调试的。
****

Rakudo Perl 6 始终首先是一种解释型动态语言。但想法是热代码将通过 JIT 优化到机器级别。Jonathan Worthington 有一个关于此的精彩演讲:反优化如何帮助我们更快?(http://jnthn.net/papers/2017-spw-deopt.pdf)。

为了回答您的问题:短期来看,我不会因为速度而选择 Perl 6,而是因为它的功能。从长远来看(未来 2-5 年),Rakudo Perl 6 将变得更快。但我不认为它永远能够输出以接近“C”速度开始运行的快速可执行文件:Perl 6 的动态特性始终是一个问题。我猜有人可能会在模块空间中制作 MoarVM 字节码 -> 足够静态的 Perl 6 程序的汇编端口。但我认为近期不会发生这种情况。当然,我希望被证明是错的 :-)

回复 作者 DarkMatter

> 为了回答您的问题:短期来看,我不会因为速度而选择 Perl 6,而是因为它的功能。从长远来看(未来 2-5 年),Rakudo Perl 6 将变得更快。
---

现在,它的执行速度与最新的 Python 或 PHP7 相当吗?或者在 2-5 年后?
Perl6 确实有一些惊人的功能。

谢谢你的回复。

回复 作者 lizmat

我只知道将其与 Perl 5 进行比较的基准测试。并且根据您正在做的事情,我想说目前单线程 Perl 6 在某些情况下与 Perl 5 相当,如果您使用大量正则表达式,则比 Perl 5 慢 10 倍。但是,如果您可以使用 `race` 或 `hyper` 并行化您的工作,通常它已经比 Perl 5 快得多。我不知道 2-5 年后情况会如何。YMMV。

回复 作者 DarkMatter

Creative Commons License本作品根据 Creative Commons Attribution-Share Alike 4.0 International License 许可。
© . All rights reserved.